
org.scribe.up.provider.BaseOAuth10Provider Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of scribe-up Show documentation
Show all versions of scribe-up Show documentation
Get a user profile after OAuth authentication process with Scribe library
The newest version!
/*
Copyright 2012 Jerome Leleu
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package org.scribe.up.provider;
import java.util.Map;
import org.scribe.exceptions.OAuthException;
import org.scribe.model.Token;
import org.scribe.model.Verifier;
import org.scribe.up.credential.OAuthCredential;
import org.scribe.up.session.UserSession;
import org.scribe.utils.OAuthEncoder;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* This class is the common implementation for provider supporting OAuth protocol version 1.0.
*
* @author Jerome Leleu
* @since 1.0.0
*/
public abstract class BaseOAuth10Provider extends BaseOAuthProvider {
protected static final Logger logger = LoggerFactory.getLogger(BaseOAuth10Provider.class);
public static final String OAUTH_TOKEN = "oauth_token";
public static final String OAUTH_VERIFIER = "oauth_verifier";
public static final String REQUEST_TOKEN = "requestToken";
/**
* Return the name of the attribute storing in session the request token.
*
* @return the name of the attribute storing in session the request token
*/
protected String getRequestTokenSessionAttributeName() {
return getType() + "#" + REQUEST_TOKEN;
}
public String getAuthorizationUrl(final UserSession session) {
init();
final Token requestToken = this.service.getRequestToken();
logger.debug("requestToken : {}", requestToken);
// save requestToken in user session
session.setAttribute(getRequestTokenSessionAttributeName(), requestToken);
final String authorizationUrl = this.service.getAuthorizationUrl(requestToken);
logger.debug("authorizationUrl : {}", authorizationUrl);
return authorizationUrl;
}
@Override
protected Token getAccessToken(final OAuthCredential credential) {
final Token tokenRequest = credential.getRequestToken();
final String token = credential.getToken();
final String verifier = credential.getVerifier();
logger.debug("tokenRequest : {}", tokenRequest);
logger.debug("token : {}", token);
logger.debug("verifier : {}", verifier);
if (tokenRequest == null) {
throw new OAuthException("Token request expired");
}
final String savedToken = tokenRequest.getToken();
logger.debug("savedToken : {}", savedToken);
if (savedToken == null || !savedToken.equals(token)) {
throw new OAuthException("Token received : " + token + " is different from saved token : " + savedToken);
}
final Verifier providerVerifier = new Verifier(verifier);
final Token accessToken = this.service.getAccessToken(tokenRequest, providerVerifier);
logger.debug("accessToken : {}", accessToken);
return accessToken;
}
@Override
protected OAuthCredential extractCredentialFromParameters(final UserSession session,
final Map parameters) {
final String[] tokens = parameters.get(OAUTH_TOKEN);
final String[] verifiers = parameters.get(OAUTH_VERIFIER);
if (tokens != null && tokens.length == 1 && verifiers != null && verifiers.length == 1) {
// get tokenRequest from user session
final Token tokenRequest = (Token) session.getAttribute(getRequestTokenSessionAttributeName());
logger.debug("tokenRequest : {}", tokenRequest);
final String token = OAuthEncoder.decode(tokens[0]);
final String verifier = OAuthEncoder.decode(verifiers[0]);
logger.debug("token : {} / verifier : {}", token, verifier);
return new OAuthCredential(tokenRequest, token, verifier, getType());
} else {
logger.error("No credential found");
return null;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy