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

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

There is a newer version: 2.0.31
Show newest version
//
// ========================================================================
// Copyright (c) 1995 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 org.eclipse.jetty.http.HttpStatus;
import org.eclipse.jetty.io.EndPoint;
import org.eclipse.jetty.security.AuthenticationState;
import org.eclipse.jetty.security.Authenticator;
import org.eclipse.jetty.security.ServerAuthException;
import org.eclipse.jetty.security.UserIdentity;
import org.eclipse.jetty.server.Request;
import org.eclipse.jetty.server.Response;
import org.eclipse.jetty.util.Callback;
import org.eclipse.jetty.util.ssl.SslContextFactory;

/**
 * CLIENT-CERT authenticator.
 *
 * 

This {@link 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 { private final SslContextFactory sslContextFactory; private boolean validateCerts = true; public SslClientCertAuthenticator(SslContextFactory sslContextFactory) { this.sslContextFactory = Objects.requireNonNull(sslContextFactory); } @Override public String getAuthenticationType() { return Authenticator.CERT_AUTH; } @Override public AuthenticationState validateRequest(Request req, Response res, Callback callback) throws ServerAuthException { if (!(req.getAttribute(EndPoint.SslSessionData.ATTRIBUTE) instanceof EndPoint.SslSessionData sslSessionData)) { Response.writeError(req, res, callback, HttpStatus.FORBIDDEN_403); return AuthenticationState.SEND_FAILURE; } X509Certificate[] certs = sslSessionData.peerCertificates(); 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, res); if (user != null) { return new UserAuthenticationSucceeded(getAuthenticationType(), user); } // try with null password user = login(username, null, req, res); if (user != null) { return new UserAuthenticationSucceeded(getAuthenticationType(), 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, res); if (user != null) { return new UserAuthenticationSucceeded(getAuthenticationType(), user); } } } if (!AuthenticationState.Deferred.isDeferred(res)) { Response.writeError(req, res, callback, HttpStatus.FORBIDDEN_403); return AuthenticationState.SEND_FAILURE; } return null; } catch (Exception e) { throw new ServerAuthException(e.getMessage()); } } /** * @return true if SSL certificate has to be validated. */ public boolean isValidateCerts() { return validateCerts; } /** * Set true if SSL certificates have to be validated.. * @param validateCerts true if SSL certificates have to be validated. */ public void setValidateCerts(boolean validateCerts) { this.validateCerts = validateCerts; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy