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

org.eclipse.jetty.ee8.security.Authenticator Maven / Gradle / Ivy

There is a newer version: 2.0.32
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.ee8.security;

import java.util.Set;
import javax.servlet.ServletContext;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import org.eclipse.jetty.ee8.nested.Authentication;
import org.eclipse.jetty.ee8.nested.Authentication.User;
import org.eclipse.jetty.security.IdentityService;
import org.eclipse.jetty.security.LoginService;
import org.eclipse.jetty.server.Server;

/**
 * Authenticator Interface
 * 

* An Authenticator is responsible for checking requests and sending * response challenges in order to authenticate a request. * Various types of {@link Authentication} are returned in order to * signal the next step in authentication. * * @version $Rev: 4793 $ $Date: 2009-03-19 00:00:01 +0100 (Thu, 19 Mar 2009) $ */ public interface Authenticator { String BASIC_AUTH = org.eclipse.jetty.security.Authenticator.BASIC_AUTH; String FORM_AUTH = org.eclipse.jetty.security.Authenticator.FORM_AUTH; String DIGEST_AUTH = org.eclipse.jetty.security.Authenticator.DIGEST_AUTH; String CERT_AUTH = org.eclipse.jetty.security.Authenticator.CERT_AUTH; String CERT_AUTH2 = org.eclipse.jetty.security.Authenticator.CERT_AUTH2; String SPNEGO_AUTH = org.eclipse.jetty.security.Authenticator.SPNEGO_AUTH; String NEGOTIATE_AUTH = org.eclipse.jetty.security.Authenticator.NEGOTIATE_AUTH; String OPENID_AUTH = org.eclipse.jetty.security.Authenticator.OPENID_AUTH; /** * Configure the Authenticator * * @param configuration the configuration */ void setConfiguration(AuthConfiguration configuration); /** * @return The name of the authentication method */ String getAuthMethod(); /** * Called prior to validateRequest. The authenticator can * manipulate the request to update it with information that * can be inspected prior to validateRequest being called. * The primary purpose of this method is to satisfy the Servlet * Spec 3.1 section 13.6.3 on handling Form authentication * where the http method of the original request causing authentication * is not the same as the http method resulting from the redirect * after authentication. * * @param request the request to manipulate */ void prepareRequest(ServletRequest request); /** * Validate a request * * @param request The request * @param response The response * @param mandatory True if authentication is mandatory. * @return An Authentication. If Authentication is successful, this will be a {@link Authentication.User}. If a response has * been sent by the Authenticator (which can be done for both successful and unsuccessful authentications), then the result will * implement {@link Authentication.ResponseSent}. If Authentication is not mandatory, then a * {@link Authentication.Deferred} may be returned. * @throws ServerAuthException if unable to validate request */ Authentication validateRequest(ServletRequest request, ServletResponse response, boolean mandatory) throws ServerAuthException; /** * is response secure * * @param request the request * @param response the response * @param mandatory if security is mandator * @param validatedUser the user that was validated * @return true if response is secure * @throws ServerAuthException if unable to test response */ boolean secureResponse(ServletRequest request, ServletResponse response, boolean mandatory, User validatedUser) throws ServerAuthException; /** * Authenticator Configuration */ interface AuthConfiguration { String getAuthMethod(); String getRealmName(); /** * Get a SecurityHandler init parameter * * @param param parameter name * @return Parameter value or null * @see SecurityHandler#getInitParameter(String) */ String getInitParameter(String param); /** * Get a SecurityHandler init parameter names * * @return Set of parameter names * @see SecurityHandler#getInitParameterNames() */ Set getInitParameterNames(); LoginService getLoginService(); IdentityService getIdentityService(); /** * Should session ID be renewed on authentication. * @return true if the session ID should be renewed on authentication */ boolean isSessionRenewedOnAuthentication(); /** * Get the interval in seconds, which if non-zero, will be set * with {@link javax.servlet.http.HttpSession#setMaxInactiveInterval(int)} * when a session is newly authenticated * @return An interval in seconds; or 0 to not set the interval * on authentication; or a negative number to make the * session never timeout after authentication. */ int getSessionMaxInactiveIntervalOnAuthentication(); } /** * Authenticator Factory */ interface Factory { Authenticator getAuthenticator(Server server, ServletContext context, AuthConfiguration configuration, IdentityService identityService, LoginService loginService); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy