Chromium Code Reviews| Index: components/proximity_auth/cryptauth/cryptauth_access_token_fetcher.cc |
| diff --git a/components/proximity_auth/cryptauth/cryptauth_access_token_fetcher.cc b/components/proximity_auth/cryptauth/cryptauth_access_token_fetcher.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..764cff386ce223d0a3f069bfb0aae1299f159f4f |
| --- /dev/null |
| +++ b/components/proximity_auth/cryptauth/cryptauth_access_token_fetcher.cc |
| @@ -0,0 +1,111 @@ |
| +// 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. |
| + |
| +#include "components/proximity_auth/cryptauth/cryptauth_access_token_fetcher.h" |
| + |
| +#include "base/callback.h" |
| +#include "google_apis/gaia/oauth2_token_service.h" |
| + |
| +namespace proximity_auth { |
| + |
| +namespace { |
| + |
| +// Implementation of CryptAuthAccessTokenFetcher fetching an access token for a |
| +// given account using the provided OAuth2TokenService. |
| +class CryptAuthAccessTokenFetcherImpl : public CryptAuthAccessTokenFetcher, |
| + public OAuth2TokenService::Consumer { |
| + public: |
| + // |token_service| is not owned, and must outlive this object. |
| + CryptAuthAccessTokenFetcherImpl(OAuth2TokenService* token_service, |
| + const std::string& account_id); |
| + ~CryptAuthAccessTokenFetcherImpl() override; |
| + |
| + // 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(CryptAuthAccessTokenFetcherImpl); |
| +}; |
|
Ilya Sherman
2015/04/06 18:53:33
I rather preferred having this as a separate file.
Tim Song
2015/04/06 23:21:17
Done.
|
| + |
| +// Returns the set of OAuth2 scopes that CryptAuth uses. |
| +OAuth2TokenService::ScopeSet GetScopes() { |
| + OAuth2TokenService::ScopeSet scopes; |
| + scopes.insert("https://www.googleapis.com/auth/cryptauth"); |
| + return scopes; |
| +} |
|
Ilya Sherman
2015/04/06 18:53:33
nit: Please move this either above or below the cl
Tim Song
2015/04/06 23:21:17
Moved definitions to another file.
|
| + |
| +CryptAuthAccessTokenFetcherImpl::CryptAuthAccessTokenFetcherImpl( |
| + OAuth2TokenService* token_service, |
| + const std::string& account_id) |
| + : OAuth2TokenService::Consumer("cryptauth_account_token_fetcher"), |
| + token_service_(token_service), |
| + account_id_(account_id), |
| + fetch_started_(false) { |
| +} |
| + |
| +CryptAuthAccessTokenFetcherImpl::~CryptAuthAccessTokenFetcherImpl() { |
| +} |
| + |
| +void CryptAuthAccessTokenFetcherImpl::FetchAccessToken( |
| + const AccessTokenCallback& callback) { |
| + if (fetch_started_) { |
| + LOG(WARNING) << "Create an instance for each token fetched. Do not reuse."; |
| + callback.Run(std::string()); |
| + return; |
| + } |
| + |
| + fetch_started_ = true; |
| + callback_ = callback; |
| + // This request will return a cached result if it is available, saving a |
| + // network round trip every time we fetch the access token. |
| + token_request_ = token_service_->StartRequest(account_id_, GetScopes(), this); |
| +} |
| + |
| +void CryptAuthAccessTokenFetcherImpl::OnGetTokenSuccess( |
| + const OAuth2TokenService::Request* request, |
| + const std::string& access_token, |
| + const base::Time& expiration_time) { |
| + callback_.Run(access_token); |
| +} |
| + |
| +void CryptAuthAccessTokenFetcherImpl::OnGetTokenFailure( |
| + const OAuth2TokenService::Request* request, |
| + const GoogleServiceAuthError& error) { |
| + callback_.Run(std::string()); |
| +} |
| + |
| +} // namespace |
| + |
| +// static. |
| +scoped_ptr<CryptAuthAccessTokenFetcher> |
| +CryptAuthAccessTokenFetcher::CreateDefault(OAuth2TokenService* token_service, |
| + const std::string& account_id) { |
| + return make_scoped_ptr( |
| + new CryptAuthAccessTokenFetcherImpl(token_service, account_id)); |
| +} |
| + |
| +} // namespace proximity_auth |