當前位置: 首頁>>代碼示例>>Java>>正文


Java OAuth2Authentication.getUserAuthentication方法代碼示例

本文整理匯總了Java中org.springframework.security.oauth2.provider.OAuth2Authentication.getUserAuthentication方法的典型用法代碼示例。如果您正苦於以下問題:Java OAuth2Authentication.getUserAuthentication方法的具體用法?Java OAuth2Authentication.getUserAuthentication怎麽用?Java OAuth2Authentication.getUserAuthentication使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.springframework.security.oauth2.provider.OAuth2Authentication的用法示例。


在下文中一共展示了OAuth2Authentication.getUserAuthentication方法的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: convertAccessToken

import org.springframework.security.oauth2.provider.OAuth2Authentication; //導入方法依賴的package包/類
/**
 * Values placed into the map will be included in the JWT token only, not the OAuth 2 response itself.
 */
@Override
public Map<String, ?> convertAccessToken(OAuth2AccessToken token, OAuth2Authentication authentication) {
	Map<String, Object> map = (Map<String, Object>) super.convertAccessToken(token, authentication);

	OAuth2Request request = authentication.getOAuth2Request();
	Set<String> authorities = request.getAuthorities().stream().map(a -> a.getAuthority()).collect(Collectors.toSet());

	ClientDetails client = clientAuthenticationService.loadClientByClientId(request.getClientId());
	if (client.getResourceIds() != null && !client.getResourceIds().isEmpty()) {
		map.put(AUDIENCE, client.getResourceIds());
	}

	Authentication userAuthentication = authentication.getUserAuthentication();
	if (userAuthentication == null) {
		map.remove("authorities");
	}

	map.put(CLIENT_AUTHORITIES, authorities);

	return map;
}
 
開發者ID:PatternFM,項目名稱:tokamak,代碼行數:25,代碼來源:JWTTokenConverter.java

示例2: getOAuth2Authentication

import org.springframework.security.oauth2.provider.OAuth2Authentication; //導入方法依賴的package包/類
@Override
protected OAuth2Authentication getOAuth2Authentication(ClientDetails client, TokenRequest tokenRequest) {

    Map<String, String> parameters = tokenRequest.getRequestParameters();
    String authorizationCode = parameters.get("code");
    String redirectUri = parameters.get(OAuth2Utils.REDIRECT_URI);
    String codeVerifier = parameters.get("code_verifier");

    if (authorizationCode == null) {
        throw new InvalidRequestException("An authorization code must be supplied.");
    }

    OAuth2Authentication storedAuth = authorizationCodeServices.consumeAuthorizationCode(authorizationCode);
    if (storedAuth == null) {
        throw new InvalidGrantException("Invalid authorization code: " + authorizationCode);
    }

    OAuth2Request pendingOAuth2Request = storedAuth.getOAuth2Request();




    // Validates code verifier
    Map<String, String> pendingOauth2RequestParams = pendingOAuth2Request.getRequestParameters();
    String codeChallenge = pendingOauth2RequestParams.get("code_challenge");
    String codeChallengeMethod = pendingOauth2RequestParams.get("code_challenge_method");

    if (codeVerifier == null && codeChallenge != null) {
        // client is using PKCE but did not send the codeVerifier
        throw new InvalidRequestException(
                "Invalid authorization code for current token request.");
    }

    if (codeVerifier != null && codeChallenge != null) {
        String hashed = codeVerifier;
        if ("S256".equals(codeChallengeMethod)) {
            hashed = DigestUtils.sha256Hex(codeVerifier);
        }

        if (!hashed.equalsIgnoreCase(codeChallenge)) {
            throw new InvalidRequestException(
                    "Invalid authorization code for current token request.");
        }
    }



    // https://jira.springsource.org/browse/SECOAUTH-333
    // This might be null, if the authorization was done without the redirect_uri parameter
    String redirectUriApprovalParameter = pendingOAuth2Request.getRequestParameters().get(
            OAuth2Utils.REDIRECT_URI);

    if ((redirectUri != null || redirectUriApprovalParameter != null)
            && !pendingOAuth2Request.getRedirectUri().equals(redirectUri)) {
        throw new RedirectMismatchException("Redirect URI mismatch.");
    }

    String pendingClientId = pendingOAuth2Request.getClientId();
    String clientId = tokenRequest.getClientId();
    if (clientId != null && !clientId.equals(pendingClientId)) {
        // just a sanity check.
        throw new InvalidClientException("Client ID mismatch");
    }

    // Secret is not required in the authorization request, so it won't be available
    // in the pendingAuthorizationRequest. We do want to check that a secret is provided
    // in the token request, but that happens elsewhere.

    Map<String, String> combinedParameters = new HashMap<String, String>(pendingOAuth2Request
            .getRequestParameters());
    // Combine the parameters adding the new ones last so they override if there are any clashes
    combinedParameters.putAll(parameters);

    // Make a new stored request with the combined parameters
    OAuth2Request finalStoredOAuth2Request = pendingOAuth2Request.createOAuth2Request(combinedParameters);

    Authentication userAuth = storedAuth.getUserAuthentication();

    return new OAuth2Authentication(finalStoredOAuth2Request, userAuth);

}
 
開發者ID:PacktPublishing,項目名稱:OAuth-2.0-Cookbook,代碼行數:82,代碼來源:CustomAuthCodeTokenGranter.java

示例3: getRoles

import org.springframework.security.oauth2.provider.OAuth2Authentication; //導入方法依賴的package包/類
public Set<String> getRoles() {
	OAuth2Authentication oauth = oauth2Authentication();
	if (oauth == null) {
		return new HashSet<String>();
	}

	if (oauth.isClientOnly()) {
		return new HashSet<String>();
	}

	Authentication userAuthentication = oauth.getUserAuthentication();

	Collection<? extends GrantedAuthority> authorities = userAuthentication.getAuthorities();
	return authorities == null ? new HashSet<String>() : authorities.stream().map(authority -> authority.getAuthority()).collect(Collectors.toSet());
}
 
開發者ID:PatternFM,項目名稱:tokamak,代碼行數:16,代碼來源:OAuth2AuthorizationContext.java

示例4: getUsername

import org.springframework.security.oauth2.provider.OAuth2Authentication; //導入方法依賴的package包/類
public String getUsername() {
	OAuth2Authentication oauth = oauth2Authentication();
	if (oauth == null) {
		return null;
	}

	if (oauth.isClientOnly()) {
		return null;
	}

	Authentication userAuthentication = oauth.getUserAuthentication();
	return (String) userAuthentication.getPrincipal();
}
 
開發者ID:PatternFM,項目名稱:tokamak,代碼行數:14,代碼來源:OAuth2AuthorizationContext.java

示例5: enhance

import org.springframework.security.oauth2.provider.OAuth2Authentication; //導入方法依賴的package包/類
/**
 * Values placed into the map will be included in the JWT token and the OAuth 2 response itself.
 */
@Override
public OAuth2AccessToken enhance(OAuth2AccessToken accessToken, OAuth2Authentication authentication) {
	DefaultOAuth2AccessToken customAccessToken = new DefaultOAuth2AccessToken(accessToken);

	Map<String, Object> map = new LinkedHashMap<String, Object>(accessToken.getAdditionalInformation());
	map.put("sub", authentication.getOAuth2Request().getClientId());
	map.put("iss", issuer);
	map.put("iat", new Date().getTime() / 1000);

	Authentication userAuthentication = authentication.getUserAuthentication();
	if (userAuthentication == null) {
		customAccessToken.setAdditionalInformation(map);
		return super.enhance(customAccessToken, authentication);
	}

	AuthenticatedAccount account = getUser(userAuthentication);
	if (account == null) {
		customAccessToken.setAdditionalInformation(map);
		return super.enhance(customAccessToken, authentication);
	}

	map.put("sub", account.getIdentfifier());

	customAccessToken.setAdditionalInformation(map);
	return super.enhance(customAccessToken, authentication);
}
 
開發者ID:PatternFM,項目名稱:tokamak,代碼行數:30,代碼來源:CustomJwtTokenEnhancer.java

示例6: extractAuthentication

import org.springframework.security.oauth2.provider.OAuth2Authentication; //導入方法依賴的package包/類
@Override
public OAuth2Authentication extractAuthentication(Map<String, ?> map) {
	List<String> authorities = (List<String>) map.get(CLIENT_AUTHORITIES);
	Collection<GrantedAuthority> grantedAuthorities = authorities.stream().map(a -> new SimpleGrantedAuthority(a)).collect(Collectors.toList());

	OAuth2Authentication authentication = super.extractAuthentication(map);
	OAuth2Request request = authentication.getOAuth2Request();
	OAuth2Request enhancedRequest = new OAuth2Request(request.getRequestParameters(), request.getClientId(), grantedAuthorities, request.isApproved(), request.getScope(), request.getResourceIds(), request.getRedirectUri(), request.getResponseTypes(), request.getExtensions());

	return new OAuth2Authentication(enhancedRequest, authentication.getUserAuthentication());
}
 
開發者ID:PatternFM,項目名稱:tokamak,代碼行數:12,代碼來源:JWTTokenConverter.java

示例7: user

import org.springframework.security.oauth2.provider.OAuth2Authentication; //導入方法依賴的package包/類
/**
 * 獲取用戶信息,可以定製
 *
 * @param principal
 * @return
 */
@RequestMapping("/user")
public RichUserDetails user(Principal principal) {
    if (principal != null) {
        OAuth2Authentication oAuth2Authentication = (OAuth2Authentication) principal;
        Authentication authentication = oAuth2Authentication.getUserAuthentication();
        
        RichUserDetails richUserDetails = (RichUserDetails) authentication.getPrincipal();
        return richUserDetails;
    }
    return null;
}
 
開發者ID:sdcuike,項目名稱:spring-boot-oauth2-demo,代碼行數:18,代碼來源:OAuth2ServerConfiguration.java

示例8: getApprovalKey

import org.springframework.security.oauth2.provider.OAuth2Authentication; //導入方法依賴的package包/類
public static String getApprovalKey(OAuth2Authentication authentication) {
  String userName = authentication.getUserAuthentication() == null ? "" : authentication.getUserAuthentication().getName();
  return getApprovalKey(authentication.getOAuth2Request().getClientId(), userName);
}
 
開發者ID:Mert-Z,項目名稱:spring-oauth2-cassandra-token-store,代碼行數:5,代碼來源:OAuthUtil.java

示例9: getUserAuthentication

import org.springframework.security.oauth2.provider.OAuth2Authentication; //導入方法依賴的package包/類
public static Authentication getUserAuthentication() {
    OAuth2Authentication auth = getTokenAuthentication();
    return auth != null ? auth.getUserAuthentication() : null;
}
 
開發者ID:GoldRenard,項目名稱:JuniperBotJ,代碼行數:5,代碼來源:SecurityUtils.java

示例10: addSocialUser

import org.springframework.security.oauth2.provider.OAuth2Authentication; //導入方法依賴的package包/類
public void addSocialUser(Principal principal) {

        OAuth2Authentication oAuth2Authentication = (OAuth2Authentication) principal;

        Authentication authentication = oAuth2Authentication.getUserAuthentication();

        Map<String, String> authenticationDetails = (LinkedHashMap<String, String>) authentication.getDetails();

        User user = new User();

        user.setName(authenticationDetails.get("name"));

        user.setLogin(authenticationDetails.get("id"));

        user.setEnabled(true);

        Role role = roleRepository.findByName("ROLE_ADMIN");
        user.getRoles().add(role);

        userRepository.save(user);
    }
 
開發者ID:arityllc,項目名稱:referenceapp,代碼行數:22,代碼來源:SocialLoginAuthorizationManager.java

示例11: socialUser

import org.springframework.security.oauth2.provider.OAuth2Authentication; //導入方法依賴的package包/類
@RequestMapping("/socialUser")
public Map<String, Object> socialUser(Principal principal) {

    OAuth2Authentication oAuth2Authentication = (OAuth2Authentication) principal;

    Authentication authentication = oAuth2Authentication.getUserAuthentication();

    Map<String, String> authenticationDetails = (LinkedHashMap<String, String>) authentication.getDetails();

    UserDetails user = null;

    try {
        user = userDetailsService.loadUserByLogin(authenticationDetails.get("id"));
    } catch (UsernameNotFoundException e) {
    }

    if (user == null) {
        socialLoginAuthorizationManager.addSocialUser(principal);
        user = userDetailsService.loadUserByLogin(authenticationDetails.get("id"));
    }

    Map<String, Object> map = new LinkedHashMap<String, Object>();

    map.put("userAuthentication", authentication.isAuthenticated());

    map.put("name", user.getUsername());

    map.put("roles", authoritiesAsSet(user.getAuthorities()));

    return map;
}
 
開發者ID:arityllc,項目名稱:referenceapp,代碼行數:32,代碼來源:OAuthService.java


注:本文中的org.springframework.security.oauth2.provider.OAuth2Authentication.getUserAuthentication方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。