use of com.github.scribejava.core.model.OAuth2AccessToken in project scribejava by scribejava.
the class OAuth2AccessTokenExtractorTest method shouldExtractTokenFromResponseWithManyParameters.
@Test
public void shouldExtractTokenFromResponseWithManyParameters() throws IOException {
final String response = "access_token=foo1234&other_stuff=yeah_we_have_this_too&number=42";
final OAuth2AccessToken extracted = extractor.extract(ok(response));
assertEquals("foo1234", extracted.getAccessToken());
}
use of com.github.scribejava.core.model.OAuth2AccessToken in project scribejava by scribejava.
the class OAuth2AccessTokenExtractorTest method shouldExtractTokenFromResponseWithExpiresParam.
@Test
public void shouldExtractTokenFromResponseWithExpiresParam() throws IOException {
final String response = "access_token=166942940015970|2.2ltzWXYNDjCtg5ZDVVJJeg__.3600.1295816400-548517159" + "|RsXNdKrpxg8L6QNLWcs2TVTmcaE&expires_in=5108";
final OAuth2AccessToken extracted = extractor.extract(ok(response));
assertEquals("166942940015970|2.2ltzWXYNDjCtg5ZDVVJJeg__.3600.1295816400-548517159|RsXNdKrpxg8L6QNLWcs2TVTmcaE", extracted.getAccessToken());
assertEquals(Integer.valueOf(5108), extracted.getExpiresIn());
}
use of com.github.scribejava.core.model.OAuth2AccessToken in project scribejava by scribejava.
the class OAuth20ServiceTest method shouldProduceCorrectRequestSync.
@Test
public void shouldProduceCorrectRequestSync() throws IOException, InterruptedException, ExecutionException {
final OAuth20Service service = new ServiceBuilder().apiKey("your_api_key").apiSecret("your_api_secret").build(new OAuth20ApiUnit());
final OAuth2AccessToken token = service.getAccessTokenPasswordGrant("user1", "password1");
final Gson json = new Gson();
assertNotNull(token);
final Map<String, String> map = json.fromJson(token.getRawResponse(), new TypeTokenImpl().getType());
assertEquals(OAuth20ServiceUnit.TOKEN, map.get(OAuthConstants.ACCESS_TOKEN));
assertEquals(OAuth20ServiceUnit.STATE, map.get(OAuthConstants.STATE));
assertEquals(OAuth20ServiceUnit.EXPIRES, map.get("expires_in"));
final String authorize = Base64Encoder.getInstance().encode(String.format("%s:%s", service.getConfig().getApiKey(), service.getConfig().getApiSecret()).getBytes(Charset.forName("UTF-8")));
assertEquals(OAuthConstants.BASIC + " " + authorize, map.get(OAuthConstants.HEADER));
assertEquals("user1", map.get("query-username"));
assertEquals("password1", map.get("query-password"));
assertEquals("password", map.get("query-grant_type"));
}
use of com.github.scribejava.core.model.OAuth2AccessToken in project scribejava by scribejava.
the class OAuth20ServiceTest method shouldProduceCorrectRequestAsync.
@Test
public void shouldProduceCorrectRequestAsync() throws ExecutionException, InterruptedException {
final OAuth20Service service = new ServiceBuilder().apiKey("your_api_key").apiSecret("your_api_secret").build(new OAuth20ApiUnit());
final OAuth2AccessToken token = service.getAccessTokenPasswordGrantAsync("user1", "password1", null).get();
final Gson json = new Gson();
assertNotNull(token);
final Map<String, String> map = json.fromJson(token.getRawResponse(), new TypeTokenImpl().getType());
assertEquals(OAuth20ServiceUnit.TOKEN, map.get(OAuthConstants.ACCESS_TOKEN));
assertEquals(OAuth20ServiceUnit.STATE, map.get(OAuthConstants.STATE));
assertEquals(OAuth20ServiceUnit.EXPIRES, map.get("expires_in"));
final String authorize = Base64Encoder.getInstance().encode(String.format("%s:%s", service.getConfig().getApiKey(), service.getConfig().getApiSecret()).getBytes(Charset.forName("UTF-8")));
assertEquals(OAuthConstants.BASIC + " " + authorize, map.get(OAuthConstants.HEADER));
assertEquals("user1", map.get("query-username"));
assertEquals("password1", map.get("query-password"));
assertEquals("password", map.get("query-grant_type"));
}
use of com.github.scribejava.core.model.OAuth2AccessToken in project scribejava by scribejava.
the class StackExchangeExample method main.
public static void main(String... args) throws IOException, InterruptedException, ExecutionException {
// Replace these with your client id, secret, application key and
// optionally site name
final String clientId = "your client id";
final String clientSecret = "your client secret";
final String key = "your client key";
// Enter one of Stack Exchange site names the user has account with.
final String site = "stackoverflow";
final String secretState = "secret" + new Random().nextInt(999_999);
final OAuth20Service service = new ServiceBuilder().apiKey(clientId).apiSecret(clientSecret).state(secretState).callback("http://www.example.com/oauth_callback/").build(StackExchangeApi.instance());
final Scanner in = new Scanner(System.in, "UTF-8");
System.out.println("=== " + NETWORK_NAME + "'s OAuth Workflow ===");
System.out.println();
// Obtain the Authorization URL
System.out.println("Fetching the Authorization URL...");
final String authorizationUrl = service.getAuthorizationUrl();
System.out.println("Got the Authorization URL!");
System.out.println("Now go and authorize ScribeJava here:");
System.out.println(authorizationUrl);
System.out.println("And paste the authorization code here");
System.out.print(">>");
final String code = in.nextLine();
System.out.println();
System.out.println("And paste the state from server here. We have set 'secretState'='" + secretState + "'.");
System.out.print(">>");
final String value = in.nextLine();
if (secretState.equals(value)) {
System.out.println("State value does match!");
} else {
System.out.println("Ooops, state value does not match!");
System.out.println("Expected = " + secretState);
System.out.println("Got = " + value);
System.out.println();
}
// Trade the Request Token and Verfier for the Access Token
System.out.println("Trading the Request Token for an Access Token...");
final OAuth2AccessToken accessToken = service.getAccessToken(code);
System.out.println("Got the Access Token!");
System.out.println("(if your curious it looks like this: " + accessToken + ", 'rawResponse'='" + accessToken.getRawResponse() + "')");
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...");
final OAuthRequest request = new OAuthRequest(Verb.GET, PROTECTED_RESOURCE_URL + "?site=" + site + "&key=" + key);
service.signRequest(accessToken, request);
final Response response = service.execute(request);
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 ScribeJava! :)");
}
Aggregations