| // 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 CHROME_BROWSER_DEVICE_IDENTITY_DEVICE_IDENTITY_PROVIDER_H_ |
| #define CHROME_BROWSER_DEVICE_IDENTITY_DEVICE_IDENTITY_PROVIDER_H_ |
| |
| #include "base/macros.h" |
| #include "components/invalidation/public/identity_provider.h" |
| |
| class DeviceOAuth2TokenService; |
| |
| // Identity provider implementation backed by DeviceOAuth2TokenService. |
| class DeviceIdentityProvider : public invalidation::IdentityProvider { |
| public: |
| explicit DeviceIdentityProvider(DeviceOAuth2TokenService* token_service); |
| ~DeviceIdentityProvider() override; |
| |
| // IdentityProvider: |
| CoreAccountId GetActiveAccountId() override; |
| bool IsActiveAccountWithRefreshToken() override; |
| std::unique_ptr<invalidation::ActiveAccountAccessTokenFetcher> |
| FetchAccessToken( |
| const std::string& oauth_consumer_name, |
| const OAuth2AccessTokenManager::ScopeSet& scopes, |
| invalidation::ActiveAccountAccessTokenCallback callback) override; |
| void InvalidateAccessToken(const OAuth2AccessTokenManager::ScopeSet& scopes, |
| const std::string& access_token) override; |
| void SetActiveAccountId(const CoreAccountId& account_id) override; |
| |
| private: |
| void OnRefreshTokenAvailable(); |
| |
| DeviceOAuth2TokenService* token_service_; |
| |
| DISALLOW_COPY_AND_ASSIGN(DeviceIdentityProvider); |
| }; |
| |
| #endif // CHROME_BROWSER_DEVICE_IDENTITY_DEVICE_IDENTITY_PROVIDER_H_ |