org.glassfish.soteria.mechanisms.FormAuthenticationMechanism Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jakarta.security.enterprise Show documentation
Show all versions of jakarta.security.enterprise Show documentation
Compatible Implementation for Jakarta Security API
/*
* Copyright (c) 2015, 2020 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0, which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the
* Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
* version 2 with the GNU Classpath Exception, which is available at
* https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
*/
package org.glassfish.soteria.mechanisms;
import static org.glassfish.soteria.Utils.notNull;
import jakarta.enterprise.inject.Typed;
import jakarta.security.enterprise.AuthenticationException;
import jakarta.security.enterprise.AuthenticationStatus;
import jakarta.security.enterprise.authentication.mechanism.http.AutoApplySession;
import jakarta.security.enterprise.authentication.mechanism.http.HttpAuthenticationMechanism;
import jakarta.security.enterprise.authentication.mechanism.http.HttpMessageContext;
import jakarta.security.enterprise.authentication.mechanism.http.LoginToContinue;
import jakarta.security.enterprise.credential.Password;
import jakarta.security.enterprise.credential.UsernamePasswordCredential;
import jakarta.security.enterprise.identitystore.IdentityStoreHandler;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
import org.glassfish.soteria.cdi.CdiUtils;
/**
* Authentication mechanism that authenticates according to the Servlet spec defined FORM
* authentication mechanism. See Servlet spec for further details.
*
* @author Arjan Tijms
*
*/
@AutoApplySession // For "is user already logged-in"
@LoginToContinue // Redirects to form page if protected resource and not-logged in
@Typed(FormAuthenticationMechanism.class) // Omit HttpAuthenticationMechanism type so it won't qualify directly as mechanism
public class FormAuthenticationMechanism implements HttpAuthenticationMechanism, LoginToContinueHolder {
private LoginToContinue loginToContinue;
@Override
public AuthenticationStatus validateRequest(HttpServletRequest request, HttpServletResponse response, HttpMessageContext httpMessageContext) throws AuthenticationException {
if (isValidFormPostback(request)) {
IdentityStoreHandler identityStoreHandler = CdiUtils.getBeanReference(IdentityStoreHandler.class);
return httpMessageContext.notifyContainerAboutLogin(
identityStoreHandler.validate(
new UsernamePasswordCredential(
request.getParameter("j_username"),
new Password(request.getParameter("j_password")))));
}
return httpMessageContext.doNothing();
}
private static boolean isValidFormPostback(HttpServletRequest request) {
return
"POST".equals(request.getMethod()) &&
request.getRequestURI().endsWith("/j_security_check") &&
notNull(request.getParameter("j_username"), request.getParameter("j_password"));
}
public LoginToContinue getLoginToContinue() {
return loginToContinue;
}
public void setLoginToContinue(LoginToContinue loginToContinue) {
this.loginToContinue = loginToContinue;
}
}