-
-
Notifications
You must be signed in to change notification settings - Fork 1.7k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Darko Zelic
committed
Feb 7, 2013
1 parent
479bfe6
commit 0359c85
Showing
2 changed files
with
106 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,42 @@ | ||
package org.scribe.builder.api; | ||
|
||
import org.scribe.extractors.AccessTokenExtractor; | ||
import org.scribe.model.OAuthConfig; | ||
import org.scribe.utils.OAuthEncoder; | ||
import org.scribe.utils.Preconditions; | ||
|
||
import org.scribe.extractors.JsonTokenExtractor; | ||
|
||
public class ViadeoApi extends DefaultApi20 | ||
{ | ||
private static final String AUTHORIZE_URL = "https://secure.viadeo.com/oauth-provider/authorize2?client_id=%s&redirect_uri=%s&response_type=code"; | ||
private static final String SCOPED_AUTHORIZE_URL = AUTHORIZE_URL + "&scope=%s"; | ||
|
||
@Override | ||
public AccessTokenExtractor getAccessTokenExtractor() | ||
{ | ||
return new JsonTokenExtractor(); | ||
} | ||
|
||
@Override | ||
public String getAccessTokenEndpoint() | ||
{ | ||
return "https://secure.viadeo.com/oauth-provider/access_token2?grant_type=authorization_code"; | ||
} | ||
|
||
@Override | ||
public String getAuthorizationUrl(OAuthConfig config) | ||
{ | ||
Preconditions.checkValidUrl(config.getCallback(), "Must provide a valid url as callback. Viadeo does not support OOB"); | ||
|
||
// Append scope if present | ||
if(config.hasScope()) | ||
{ | ||
return String.format(SCOPED_AUTHORIZE_URL, config.getApiKey(), OAuthEncoder.encode(config.getCallback()), OAuthEncoder.encode(config.getScope())); | ||
} | ||
else | ||
{ | ||
return String.format(AUTHORIZE_URL, config.getApiKey(), OAuthEncoder.encode(config.getCallback())); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,64 @@ | ||
package org.scribe.examples; | ||
|
||
import java.util.*; | ||
|
||
import org.scribe.builder.*; | ||
import org.scribe.builder.api.*; | ||
import org.scribe.model.*; | ||
import org.scribe.oauth.*; | ||
|
||
public class ViadeoExample | ||
{ | ||
private static final String NETWORK_NAME = "Viadeo"; | ||
private static final String PROTECTED_RESOURCE_URL = "https://api.viadeo.com/me?user_detail=full"; | ||
private static final Token EMPTY_TOKEN = null; | ||
|
||
public static void main(String[] args) | ||
{ | ||
// Replace these with your own api key and secret | ||
String apiKey = "your_app_id"; | ||
String apiSecret = "your_api_secret"; | ||
OAuthService service = new ServiceBuilder() | ||
.provider(ViadeoApi.class) | ||
.apiKey(apiKey) | ||
.apiSecret(apiSecret) | ||
.callback("http://www.example.com/oauth_callback/") | ||
.build(); | ||
Scanner in = new Scanner(System.in); | ||
|
||
System.out.println("=== " + NETWORK_NAME + "'s OAuth Workflow ==="); | ||
System.out.println(); | ||
|
||
// Obtain the Authorization URL | ||
System.out.println("Fetching the Authorization URL..."); | ||
String authorizationUrl = service.getAuthorizationUrl(EMPTY_TOKEN); | ||
System.out.println("Got the Authorization URL!"); | ||
System.out.println("Now go and authorize Scribe here:"); | ||
System.out.println(authorizationUrl); | ||
System.out.println("And paste the authorization code here"); | ||
System.out.print(">>"); | ||
Verifier verifier = new Verifier(in.nextLine()); | ||
System.out.println(); | ||
|
||
// Trade the Request Token and Verfier for the Access Token | ||
System.out.println("Trading the Request Token for an Access Token..."); | ||
Token accessToken = service.getAccessToken(EMPTY_TOKEN, verifier); | ||
System.out.println("Got the Access Token!"); | ||
System.out.println("(if your curious it looks like this: " + accessToken + " )"); | ||
System.out.println(); | ||
|
||
// Now let's go and ask for a protected resource! | ||
System.out.println("Now we're going to access a protected resource..."); | ||
OAuthRequest request = new OAuthRequest(Verb.GET, PROTECTED_RESOURCE_URL); | ||
service.signRequest(accessToken, request); | ||
Response response = request.send(); | ||
System.out.println("Got it! Lets see what we found..."); | ||
System.out.println(); | ||
System.out.println(response.getCode()); | ||
System.out.println(response.getBody()); | ||
|
||
System.out.println(); | ||
System.out.println("Thats it man! Go and build something awesome with Scribe! :)"); | ||
|
||
} | ||
} |