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

waffle.spring.WindowsAuthenticationToken Maven / Gradle / Ivy

There is a newer version: 1.8.3
Show newest version
/**
 * Waffle (https://github.com/Waffle/waffle)
 *
 * Copyright (c) 2010-2016 Application Security, Inc.
 *
 * All rights reserved. This program and the accompanying materials are made available under the terms of the Eclipse
 * Public License v1.0 which accompanies this distribution, and is available at
 * https://www.eclipse.org/legal/epl-v10.html.
 *
 * Contributors: Application Security, Inc.
 */
package waffle.spring;

import java.util.ArrayList;
import java.util.Collection;

import org.springframework.security.core.Authentication;
import org.springframework.security.core.GrantedAuthority;
import org.springframework.security.core.authority.SimpleGrantedAuthority;

import waffle.servlet.WindowsPrincipal;
import waffle.windows.auth.WindowsAccount;

/**
 * A Windows authentication token.
 * 
 * @author dblock[at]dblock[dot]org
 */
public class WindowsAuthenticationToken implements Authentication {

    /** The Constant serialVersionUID. */
    private static final long                   serialVersionUID                  = 1L;

    /**
     * The {@link GrantedAuthorityFactory} that is used by default if a custom one is not specified. This default
     * {@link GrantedAuthorityFactory} is a {@link FqnGrantedAuthorityFactory} with prefix {@code "ROLE_"} and will
     * convert the fqn to uppercase
     */
    public static final GrantedAuthorityFactory DEFAULT_GRANTED_AUTHORITY_FACTORY = new FqnGrantedAuthorityFactory(
            "ROLE_", true);

    /**
     * The {@link GrantedAuthority} that will be added to every WindowsAuthenticationToken, unless another (or null) is
     * specified.
     */
    public static final GrantedAuthority        DEFAULT_GRANTED_AUTHORITY         = new SimpleGrantedAuthority(
            "ROLE_USER");

    /** The principal. */
    private final WindowsPrincipal              principal;

    /** The authorities. */
    private final Collection  authorities;

    /**
     * Convenience constructor that calls
     * {@link #WindowsAuthenticationToken(WindowsPrincipal, GrantedAuthorityFactory, GrantedAuthority)} with:
     * 
    *
  • the given identity,
  • *
  • the {@link #DEFAULT_GRANTED_AUTHORITY_FACTORY}
  • *
  • the {@link #DEFAULT_GRANTED_AUTHORITY}
  • *
* . * * @param identity * The {@link WindowsPrincipal} for which this token exists. */ public WindowsAuthenticationToken(final WindowsPrincipal identity) { this(identity, WindowsAuthenticationToken.DEFAULT_GRANTED_AUTHORITY_FACTORY, WindowsAuthenticationToken.DEFAULT_GRANTED_AUTHORITY); } /** * Instantiates a new windows authentication token. * * @param identity * The {@link WindowsPrincipal} for which this token exists. * @param grantedAuthorityFactory * used to construct {@link GrantedAuthority}s for each of the groups to which the * {@link WindowsPrincipal} belongs * @param defaultGrantedAuthority * if not null, this {@link GrantedAuthority} will always be added to the granted authorities list */ public WindowsAuthenticationToken(final WindowsPrincipal identity, final GrantedAuthorityFactory grantedAuthorityFactory, final GrantedAuthority defaultGrantedAuthority) { this.principal = identity; this.authorities = new ArrayList<>(); if (defaultGrantedAuthority != null) { this.authorities.add(defaultGrantedAuthority); } for (final WindowsAccount group : this.principal.getGroups().values()) { this.authorities.add(grantedAuthorityFactory.createGrantedAuthority(group)); } } /* * (non-Javadoc) * @see org.springframework.security.core.Authentication#getAuthorities() */ @Override public Collection getAuthorities() { return this.authorities; } /* * (non-Javadoc) * @see org.springframework.security.core.Authentication#getCredentials() */ @Override public Object getCredentials() { return null; } /* * (non-Javadoc) * @see org.springframework.security.core.Authentication#getDetails() */ @Override public Object getDetails() { return null; } /* * (non-Javadoc) * @see org.springframework.security.core.Authentication#getPrincipal() */ @Override public Object getPrincipal() { return this.principal; } /* * (non-Javadoc) * @see org.springframework.security.core.Authentication#isAuthenticated() */ @Override public boolean isAuthenticated() { return this.principal != null; } /* * (non-Javadoc) * @see org.springframework.security.core.Authentication#setAuthenticated(boolean) */ @Override public void setAuthenticated(final boolean authenticated) { throw new IllegalArgumentException(); } /* * (non-Javadoc) * @see java.security.Principal#getName() */ @Override public String getName() { return this.principal.getName(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy