All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eclipse.jetty.security.authentication.SslClientCertAuthenticator Maven / Gradle / Ivy

//
// ========================================================================
// Copyright (c) 1995-2021 Mort Bay Consulting Pty Ltd and others.
//
// This program and the accompanying materials are made available under the
// terms of the Eclipse Public License v. 2.0 which is available at
// https://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0
// which is available at https://www.apache.org/licenses/LICENSE-2.0.
//
// SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
// ========================================================================
//

package org.eclipse.jetty.security.authentication;

import java.security.Principal;
import java.security.cert.X509Certificate;
import java.util.Base64;
import java.util.Objects;

import jakarta.servlet.ServletRequest;
import jakarta.servlet.ServletResponse;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
import org.eclipse.jetty.security.ServerAuthException;
import org.eclipse.jetty.security.UserAuthentication;
import org.eclipse.jetty.server.Authentication;
import org.eclipse.jetty.server.Authentication.User;
import org.eclipse.jetty.server.UserIdentity;
import org.eclipse.jetty.util.security.Constraint;
import org.eclipse.jetty.util.ssl.SslContextFactory;

/**
 * CLIENT-CERT authenticator.
 *
 * 

This {@link org.eclipse.jetty.security.Authenticator} implements client certificate authentication. * The client certificates available in the request will be verified against the configured {@link SslContextFactory} instance *

*/ public class SslClientCertAuthenticator extends LoginAuthenticator { /** * Set to true if SSL certificate validation is not required * per default it's true as this is the goal of this implementation */ private boolean validateCerts = true; private SslContextFactory sslContextFactory; public SslClientCertAuthenticator(SslContextFactory sslContextFactory) { super(); Objects.nonNull(sslContextFactory); this.sslContextFactory = sslContextFactory; } @Override public String getAuthMethod() { return Constraint.__CERT_AUTH; } @Override public Authentication validateRequest(ServletRequest req, ServletResponse res, boolean mandatory) throws ServerAuthException { if (!mandatory) return new DeferredAuthentication(this); HttpServletRequest request = (HttpServletRequest)req; HttpServletResponse response = (HttpServletResponse)res; X509Certificate[] certs = (X509Certificate[])request.getAttribute("jakarta.servlet.request.X509Certificate"); try { // Need certificates. if (certs != null && certs.length > 0) { if (validateCerts) { sslContextFactory.validateCerts(certs); } for (X509Certificate cert : certs) { if (cert == null) continue; Principal principal = cert.getSubjectDN(); if (principal == null) principal = cert.getIssuerDN(); final String username = principal == null ? "clientcert" : principal.getName(); UserIdentity user = login(username, "", req); if (user != null) { return new UserAuthentication(getAuthMethod(), user); } // try with null password user = login(username, null, req); if (user != null) { return new UserAuthentication(getAuthMethod(), user); } // try with certs sig against login service as previous behaviour final char[] credential = Base64.getEncoder().encodeToString(cert.getSignature()).toCharArray(); user = login(username, credential, req); if (user != null) { return new UserAuthentication(getAuthMethod(), user); } } } if (!DeferredAuthentication.isDeferred(response)) { response.sendError(HttpServletResponse.SC_FORBIDDEN); return Authentication.SEND_FAILURE; } return Authentication.UNAUTHENTICATED; } catch (Exception e) { throw new ServerAuthException(e.getMessage()); } } @Override public boolean secureResponse(ServletRequest req, ServletResponse res, boolean mandatory, User validatedUser) throws ServerAuthException { return true; } /** * @return true if SSL certificate has to be validated */ public boolean isValidateCerts() { return validateCerts; } /** * @param validateCerts true if SSL certificates have to be validated */ public void setValidateCerts(boolean validateCerts) { validateCerts = validateCerts; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy