Index: components/proximity_auth/cryptauth/cryptauth_account_token_fetcher.h |
diff --git a/components/proximity_auth/cryptauth/cryptauth_account_token_fetcher.h b/components/proximity_auth/cryptauth/cryptauth_account_token_fetcher.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..717378c2087bdae836c7a82e3019eec5d3b1a100 |
--- /dev/null |
+++ b/components/proximity_auth/cryptauth/cryptauth_account_token_fetcher.h |
@@ -0,0 +1,56 @@ |
+// Copyright 2014 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef COMPONENTS_PROXIMITY_AUTH_CRYPT_AUTH_ACCOUNT_TOKEN_FETCHER_IMPL_H |
+#define COMPONENTS_PROXIMITY_AUTH_CRYPT_AUTH_ACCOUNT_TOKEN_FETCHER_IMPL_H |
+ |
+#include "base/callback.h" |
+#include "components/proximity_auth/cryptauth/cryptauth_access_token_fetcher.h" |
+#include "google_apis/gaia/oauth2_token_service.h" |
+ |
+namespace proximity_auth { |
+ |
+// Implementation of CryptAuthAccessTokenFetcher fetching an access token for a |
+// given account using the provided OAuth2TokenService. |
+class CryptAuthAccountTokenFetcher : public CryptAuthAccessTokenFetcher, |
+ public OAuth2TokenService::Consumer { |
+ public: |
+ // |token_service| is not owned, and must outlive this object. |
+ CryptAuthAccountTokenFetcher(OAuth2TokenService* token_service, |
+ const std::string& account_id); |
+ virtual ~CryptAuthAccountTokenFetcher(); |
+ |
+ // CryptAuthAccessTokenFetcher: |
+ void FetchAccessToken(const AccessTokenCallback& callback) override; |
+ |
+ private: |
+ // OAuth2TokenService::Consumer: |
+ void OnGetTokenSuccess(const OAuth2TokenService::Request* request, |
+ const std::string& access_token, |
+ const base::Time& expiration_time) override; |
+ void OnGetTokenFailure(const OAuth2TokenService::Request* request, |
+ const GoogleServiceAuthError& error) override; |
+ |
+ // System service that caches and fetches tokens for a given account. |
+ // Not owned. |
+ OAuth2TokenService* token_service_; |
+ |
+ // The account id for whom to mint the token. |
+ std::string account_id_; |
+ |
+ // True if FetchAccessToken() has been called. |
+ bool fetch_started_; |
+ |
+ // Stores the request from |token_service_| to mint the token. |
+ scoped_ptr<OAuth2TokenService::Request> token_request_; |
+ |
+ // Callback to invoke when the token fetch succeeds or fails. |
+ AccessTokenCallback callback_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(CryptAuthAccountTokenFetcher); |
+}; |
+ |
+} // namespace proximity_auth |
+ |
+#endif // COMPONENTS_PROXIMITY_AUTH_CRYPT_AUTH_ACCESS_TOKEN_FETCHER_IMPL_H |