本文整理匯總了Java中org.springframework.security.oauth2.common.OAuth2AccessToken.getRefreshToken方法的典型用法代碼示例。如果您正苦於以下問題:Java OAuth2AccessToken.getRefreshToken方法的具體用法?Java OAuth2AccessToken.getRefreshToken怎麽用?Java OAuth2AccessToken.getRefreshToken使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類org.springframework.security.oauth2.common.OAuth2AccessToken
的用法示例。
在下文中一共展示了OAuth2AccessToken.getRefreshToken方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: getValidToken
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
private OAuth2AccessToken getValidToken(String userName, String org, String space) throws SLException {
OAuth2AccessToken token = tokenService.getToken(userName);
if (token == null) {
throw new SLException(Messages.NO_VALID_TOKEN_FOUND, userName);
}
if (token.isExpired() && token.getRefreshToken() == null) {
tokenService.removeToken(token);
if (org != null && space != null) {
releaseClientFromCache(token, org, space);
}
throw new SLException(Messages.TOKEN_EXPIRED, userName);
}
return token;
}
示例2: fetch
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
public static EAccessToken fetch(OAuth2Authentication oAuth2Authentication, OAuth2AccessToken accessToken){
EAccessToken eAccessToken = new EAccessToken();
eAccessToken.setOpenUser(fetch(oAuth2Authentication));
Object details = oAuth2Authentication.getDetails();
if(details instanceof OAuth2AuthenticationDetails){
OAuth2AuthenticationDetails details1 = (OAuth2AuthenticationDetails) details;
eAccessToken.setRemoteAddress(details1.getRemoteAddress());
eAccessToken.setSessionId(details1.getSessionId());
}
eAccessToken.setTokenType(accessToken.getTokenType());
eAccessToken.setTokenValue(accessToken.getValue());
eAccessToken.setExpiresIn(accessToken.getExpiresIn());
if (accessToken.getRefreshToken() != null) {
eAccessToken.setRefreshToken(accessToken.getRefreshToken().getValue());
}
if (accessToken.getScope() != null) {
String scopes = Strings.join2("|", accessToken.getScope().toArray(new String[]{}));
eAccessToken.setScopes(scopes);
}
return eAccessToken;
}
示例3: storeAccessToken
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
public void storeAccessToken(OAuth2AccessToken token, OAuth2Authentication authentication) {
String refreshToken = null;
if (token.getRefreshToken() != null) {
refreshToken = token.getRefreshToken().getValue();
}
if (readAccessToken(token.getValue())!=null) {
removeAccessToken(token.getValue());
}
String bid = getAuthorizationDetail(authentication).get("bid");
String pid = getAuthorizationDetail(authentication).get("pid");
jdbcTemplate.update(insertAccessTokenSql, new Object[] { extractTokenKey(token.getValue()),
new SqlLobValue(serializeAccessToken(token)), authenticationKeyGenerator.extractKey(authentication),
authentication.isClientOnly() ? null : authentication.getName(),
authentication.getOAuth2Request().getClientId(),
new SqlLobValue(serializeAuthentication(authentication)), extractTokenKey(refreshToken),bid,pid}, new int[] {
Types.VARCHAR, Types.BLOB, Types.VARCHAR, Types.VARCHAR, Types.VARCHAR, Types.BLOB, Types.VARCHAR,Types.VARCHAR,Types.VARCHAR });
}
示例4: revokeToken
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
@Override
public boolean revokeToken(String tokenValue) {
OAuth2AccessToken accessToken = tokenStore.readAccessToken(tokenValue);
if (accessToken == null) {
return false;
}
if (accessToken.getRefreshToken() != null) {
tokenStore.removeRefreshToken(accessToken.getRefreshToken());
}
tokenStore.removeAccessToken(accessToken);
return true;
}
示例5: getToken
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
/**
* Chooses a token among all tokens for this user in the token store.
*
* @param tokenStore the token store to search in
* @param userName the username
* @return the chosen token, or null if no token was found
*/
public OAuth2AccessToken getToken(String userName) {
OAuth2AccessToken token = null;
Collection<OAuth2AccessToken> tokens = tokenStore.findTokensByUserName(userName);
for (OAuth2AccessToken tokenx : tokens) {
// If a token is already found, overwrite it if the new token:
// 1) has a refresh token, and the current token hasn't, or
// 2) expires later than the current token
if (token == null || ((tokenx.getRefreshToken() != null) && (token.getRefreshToken() == null))
|| (tokenx.getExpiresIn() > token.getExpiresIn())) {
token = tokenx;
}
}
return token;
}
示例6: storeAccessToken
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
@Override
public void storeAccessToken(OAuth2AccessToken token, OAuth2Authentication authentication) {
String tokenId = token.getValue();
final RefreshTokenEntity refreshToken;
String authenticationKey = authenticationKeyGenerator.extractKey(authentication);
if (token.getRefreshToken() != null) {
refreshToken = refreshTokenRepository.findOneByTokenId(token.getRefreshToken().getValue()).orElseGet(() -> refreshTokenRepository.save(RefreshTokenEntity.builder().tokenId(token.getRefreshToken().getValue()).token(token.getRefreshToken()).authentication(authentication).build()));
} else {
refreshToken = null;
}
accessTokenRepository.findOneByAuthenticationId(authenticationKey).ifPresent(accessTokenEntity -> {
if (!tokenId.equals(accessTokenEntity.getTokenId())) {
accessTokenRepository.delete(accessTokenEntity);
}
});
AccessTokenEntity entityToSave = accessTokenRepository.findOneByTokenId(tokenId).map(accessTokenEntity -> {
accessTokenEntity.setToken(token);
accessTokenEntity.setAuthenticationId(authenticationKey);
accessTokenEntity.setAuthentication(authentication);
accessTokenEntity.setUserName(authentication.isClientOnly() ? null : authentication.getName());
accessTokenEntity.setClientId(authentication.getOAuth2Request().getClientId());
accessTokenEntity.setRefreshToken(refreshToken);
return accessTokenEntity;
}).orElseGet(() -> AccessTokenEntity.builder().tokenId(tokenId).token(token).authenticationId(authenticationKey).authentication(authentication).userName(authentication.isClientOnly() ? null : authentication.getName()).clientId(authentication.getOAuth2Request().getClientId()).refreshToken(refreshToken).build());
accessTokenRepository.save(entityToSave);
}
示例7: createAccessToken
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
@Override
public OAuth2AccessToken createAccessToken(OAuth2Authentication authentication) {
setCustomDetails(authentication);
OAuth2AccessToken existingAccessToken = tokenStore.getAccessToken(authentication);
OAuth2RefreshToken refreshToken = null;
if (existingAccessToken != null) {
if (existingAccessToken.isExpired()) {
if (existingAccessToken.getRefreshToken() != null) {
refreshToken = existingAccessToken.getRefreshToken();
// The token store could remove the refresh token when the
// access token is removed, but we want to
// be sure...
tokenStore.removeRefreshToken(refreshToken);
}
tokenStore.removeAccessToken(existingAccessToken);
} else {
// Re-store the access token in case the authentication has changed
tokenStore.storeAccessToken(existingAccessToken, authentication);
return existingAccessToken;
}
}
// Only create a new refresh token if there wasn't an existing one
// associated with an expired access token.
// Clients might be holding existing refresh tokens, so we re-use it in
// the case that the old access token
// expired.
if (refreshToken == null) {
refreshToken = createRefreshToken(authentication);
} else if (refreshToken instanceof ExpiringOAuth2RefreshToken) {
ExpiringOAuth2RefreshToken expiring = (ExpiringOAuth2RefreshToken) refreshToken;
if (System.currentTimeMillis() > expiring.getExpiration().getTime()) {
refreshToken = createRefreshToken(authentication);
}
}
OAuth2AccessToken accessToken = createAccessToken(authentication, refreshToken);
tokenStore.storeAccessToken(accessToken, authentication);
// In case it was modified
refreshToken = accessToken.getRefreshToken();
if (refreshToken != null) {
tokenStore.storeRefreshToken(refreshToken, authentication);
}
return accessToken;
}
示例8: obtainAccessToken
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
public OAuth2AccessToken obtainAccessToken(OAuth2ProtectedResourceDetails resource, AccessTokenRequest request) throws UserRedirectRequiredException, AccessDeniedException {
OAuth2AccessToken accessToken = null;
OAuth2AccessToken existingToken = null;
Authentication auth = SecurityContextHolder.getContext().getAuthentication();
if(auth instanceof AnonymousAuthenticationToken && !resource.isClientOnly()) {
throw new InsufficientAuthenticationException("Authentication is required to obtain an access token (anonymous not allowed)");
} else {
if(resource.isClientOnly() || auth != null && auth.isAuthenticated()) {
existingToken = request.getExistingToken();
if(existingToken == null && this.clientTokenServices != null) {
existingToken = this.clientTokenServices.getAccessToken(resource, auth);
}
if(existingToken != null) {
if(existingToken.isExpired()) {
if(this.clientTokenServices != null) {
this.clientTokenServices.removeAccessToken(resource, auth);
}
OAuth2RefreshToken refreshToken = existingToken.getRefreshToken();
if(refreshToken != null) {
accessToken = this.refreshAccessToken(resource, refreshToken, request);
}
} else {
accessToken = existingToken;
}
}
}
if(accessToken == null) {
accessToken = this.obtainNewAccessTokenInternal(resource, request);
if(accessToken == null) {
System.out.println("An OAuth 2 access token must be obtained or an exception thrown.");
throw new IllegalStateException("An OAuth 2 access token must be obtained or an exception thrown.");
}
}
if(this.clientTokenServices != null && (resource.isClientOnly() || auth != null && auth.isAuthenticated())) {
this.clientTokenServices.saveAccessToken(resource, auth, accessToken);
}
return accessToken;
}
}
示例9: createCredentials
import org.springframework.security.oauth2.common.OAuth2AccessToken; //導入方法依賴的package包/類
private static CloudCredentials createCredentials(OAuth2AccessToken token) {
boolean refreshable = (token.getRefreshToken() != null);
return new CloudCredentials(token, refreshable);
}