AuthenticationTokens.java

package cn.home1.oss.lib.security.internal;

import static cn.home1.oss.lib.security.api.GenericUser.isGenericUser;

import com.google.common.collect.ImmutableSet;

import cn.home1.oss.lib.security.api.GenericUser;
import cn.home1.oss.lib.webmvc.api.TypeSafeToken;

import org.springframework.security.core.Authentication;
import org.springframework.security.core.GrantedAuthority;
import org.springframework.security.core.context.SecurityContext;
import org.springframework.security.core.context.SecurityContextHolder;
import org.springframework.security.web.authentication.preauth.PreAuthenticatedAuthenticationToken;

import java.util.Collection;

/**
 * Created by zhanghaolun on 16/10/30.
 */
@SuppressWarnings({"PMD.AbstractNaming", "PMD.AbstractClassWithoutAbstractMethod"})
public abstract class AuthenticationTokens {

  private AuthenticationTokens() {
  }

  public static PreAuthenticatedAuthenticationToken authenticated( //
    final PreAuthenticatedAuthenticationToken authentication //
  ) {
    final PreAuthenticatedAuthenticationToken result;

    if (authentication == null) {
      result = null;
    } else {
      authentication.setAuthenticated(true);
      authentication.eraseCredentials();

      final Object principal = authentication.getPrincipal();
      final Object credentials = authentication.getCredentials();

      final GenericUser genericUser = isGenericUser(principal) ? (GenericUser) principal : null;

      if (genericUser == null) {
        result = authentication;
      } else {
        genericUser.eraseCredentials();
        final Collection<GrantedAuthority> authorities = genericUser.getAuthorities() != null ? //
          genericUser.getAuthorities() : ImmutableSet.of();
        result = new PreAuthenticatedAuthenticationToken(principal, credentials, authorities);
      }
    }
    return result;
  }

  public static String rawToken(final Authentication authentication, final TypeSafeToken<GenericUser> token) {
    // TODO find OAuth2Authentication's header Authorization: Bearer?

    final String result;
    if (authentication instanceof PreAuthenticatedAuthenticationToken) {
      final Object principal = authentication.getPrincipal();
      final GenericUser genericUser = isGenericUser(principal) ? (GenericUser) principal : null;
      result = genericUser != null ? (String) authentication.getCredentials() : null;
    } else {
      final GenericUser genericUser = GenericUser.fromPrincipal(authentication);
      result = token.toToken(genericUser);
    }
    return result;
  }

  public static Boolean tokenInSecurityContext() {
    final SecurityContext securityContext = SecurityContextHolder.getContext();
    final Authentication authentication = securityContext.getAuthentication();
    return authentication != null && authentication.isAuthenticated();
  }

  public static String tokenFromSecurityContext(final TypeSafeToken<GenericUser> token) {
    final SecurityContext securityContext = SecurityContextHolder.getContext();
    final Authentication authentication = securityContext.getAuthentication();

    final String result;
    if (authentication != null && authentication.isAuthenticated()) {
      result = AuthenticationTokens.rawToken(authentication, token);
    } else {
      result = null;
    }

    return result;
  }

  //  public static boolean containsUserInfo(final Authentication authentication) {
  //    final boolean result;
  //    if (authentication == null) {
  //      result = false;
  //    } else if (authentication instanceof OAuth2Authentication) {
  //      final OAuth2Authentication oAuth2Auth = (OAuth2Authentication) authentication;
  //      result = !oAuth2Auth.isClientOnly();
  //    } else if (authentication instanceof AbstractAuthenticationToken) {
  //      // PreAuthenticatedAuthenticationToken
  //      result = isGenericUser(authentication.getPrincipal());
  //    } else {
  //      result = false;
  //    }
  //    return result;
  //  }
}