summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--google_apis/gaia/gaia_oauth_client.cc18
-rw-r--r--google_apis/gaia/gaia_oauth_client.h8
-rw-r--r--google_apis/gaia/gaia_oauth_client_unittest.cc30
3 files changed, 49 insertions, 7 deletions
diff --git a/google_apis/gaia/gaia_oauth_client.cc b/google_apis/gaia/gaia_oauth_client.cc
index 56647f4..adb8c6f 100644
--- a/google_apis/gaia/gaia_oauth_client.cc
+++ b/google_apis/gaia/gaia_oauth_client.cc
@@ -59,7 +59,8 @@ class GaiaOAuthClient::Core
void GetUserInfo(const std::string& oauth_access_token,
int max_retries,
Delegate* delegate);
- void GetTokenInfo(const std::string& oauth_access_token,
+ void GetTokenInfo(const std::string& qualifier,
+ const std::string& query,
int max_retries,
Delegate* delegate);
@@ -189,14 +190,15 @@ void GaiaOAuthClient::Core::GetUserInfoImpl(
request_->Start();
}
-void GaiaOAuthClient::Core::GetTokenInfo(const std::string& oauth_access_token,
+void GaiaOAuthClient::Core::GetTokenInfo(const std::string& qualifier,
+ const std::string& query,
int max_retries,
Delegate* delegate) {
DCHECK_EQ(request_type_, NO_PENDING_REQUEST);
DCHECK(!request_.get());
request_type_ = TOKEN_INFO;
std::string post_body =
- "access_token=" + net::EscapeUrlEncodedData(oauth_access_token, true);
+ qualifier + "=" + net::EscapeUrlEncodedData(query, true);
MakeGaiaRequest(GURL(GaiaUrls::GetInstance()->oauth2_token_info_url()),
post_body,
max_retries,
@@ -396,7 +398,15 @@ void GaiaOAuthClient::GetUserInfo(const std::string& access_token,
void GaiaOAuthClient::GetTokenInfo(const std::string& access_token,
int max_retries,
Delegate* delegate) {
- return core_->GetTokenInfo(access_token, max_retries, delegate);
+ return core_->GetTokenInfo("access_token", access_token, max_retries,
+ delegate);
+}
+
+void GaiaOAuthClient::GetTokenHandleInfo(const std::string& token_handle,
+ int max_retries,
+ Delegate* delegate) {
+ return core_->GetTokenInfo("token_handle", token_handle, max_retries,
+ delegate);
}
} // namespace gaia
diff --git a/google_apis/gaia/gaia_oauth_client.h b/google_apis/gaia/gaia_oauth_client.h
index 68eb766..e3ecd0d 100644
--- a/google_apis/gaia/gaia_oauth_client.h
+++ b/google_apis/gaia/gaia_oauth_client.h
@@ -128,6 +128,14 @@ class GaiaOAuthClient {
int max_retries,
Delegate* delegate);
+ // Call the tokeninfo API for given |token_handle|, returning a dictionary of
+ // response values. Basic results will be returned via
+ // |OnGetTokenInfoResponse| call: audience, expires_in, user_id. See
+ // |max_retries| docs above.
+ void GetTokenHandleInfo(const std::string& token_handle,
+ int max_retries,
+ Delegate* delegate);
+
private:
// The guts of the implementation live in this class.
class Core;
diff --git a/google_apis/gaia/gaia_oauth_client_unittest.cc b/google_apis/gaia/gaia_oauth_client_unittest.cc
index a828beb..6197b89 100644
--- a/google_apis/gaia/gaia_oauth_client_unittest.cc
+++ b/google_apis/gaia/gaia_oauth_client_unittest.cc
@@ -127,6 +127,7 @@ class MockOAuthFetcherFactory : public net::URLFetcherFactory,
};
const std::string kTestAccessToken = "1/fFAGRNJru1FTz70BzhT3Zg";
+const std::string kTestAccessTokenHandle = "1/kjhH87dfgkj87Hhj5KJkjZ";
const std::string kTestRefreshToken =
"1/6BMfW9j53gdGImsixUH6kU5RsR4zwI9lUVX-tqf8JXQ";
const std::string kTestUserEmail = "a_user@gmail.com";
@@ -165,7 +166,12 @@ const std::string kDummyTokenInfoResult =
"\"audience\": \"1234567890.apps.googleusercontent.com\","
"\"scope\": \"https://googleapis.com/oauth2/v2/tokeninfo\","
"\"expires_in\":" + base::IntToString(kTestExpiresIn) + "}";
-}
+
+const std::string kDummyTokenHandleInfoResult =
+ "{\"audience\": \"1234567890.apps.googleusercontent.com\","
+ "\"expires_in\":" + base::IntToString(kTestExpiresIn) + "}";
+
+} // namespace
namespace gaia {
@@ -381,11 +387,29 @@ TEST_F(GaiaOAuthClientTest, GetTokenInfo) {
factory.set_results(kDummyTokenInfoResult);
GaiaOAuthClient auth(GetRequestContext());
- auth.GetTokenInfo("access_token", 1, &delegate);
+ auth.GetTokenInfo("some_token", 1, &delegate);
std::string issued_to;
- ASSERT_TRUE(captured_result->GetString("issued_to", &issued_to));
+ ASSERT_TRUE(captured_result->GetString("issued_to", &issued_to));
ASSERT_EQ("1234567890.apps.googleusercontent.com", issued_to);
}
+TEST_F(GaiaOAuthClientTest, GetTokenHandleInfo) {
+ const base::DictionaryValue* captured_result;
+
+ MockGaiaOAuthClientDelegate delegate;
+ EXPECT_CALL(delegate, OnGetTokenInfoResponsePtr(_))
+ .WillOnce(SaveArg<0>(&captured_result));
+
+ MockOAuthFetcherFactory factory;
+ factory.set_results(kDummyTokenHandleInfoResult);
+
+ GaiaOAuthClient auth(GetRequestContext());
+ auth.GetTokenHandleInfo("some_handle", 1, &delegate);
+
+ std::string audience;
+ ASSERT_TRUE(captured_result->GetString("audience", &audience));
+ ASSERT_EQ("1234567890.apps.googleusercontent.com", audience);
+}
+
} // namespace gaia