blob: 208c349571e888718b8ca9b572168c7e752873ee [file] [log] [blame]
// 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 EXTENSIONS_SHELL_BROWSER_SHELL_OAUTH2_TOKEN_SERVICE_H_
#define EXTENSIONS_SHELL_BROWSER_SHELL_OAUTH2_TOKEN_SERVICE_H_
#include <string>
#include "base/macros.h"
#include "google_apis/gaia/oauth2_token_service.h"
namespace content {
class BrowserContext;
}
namespace extensions {
// Requests OAuth2 access tokens for app_shell. Requires the OAuth2 refresh
// token to be set explicitly. Only stores a single refresh token for a single
// user account. Created and accessed on the UI thread. Only one instance is
// allowed.
class ShellOAuth2TokenService : public OAuth2TokenService {
public:
ShellOAuth2TokenService(content::BrowserContext* browser_context,
std::string account_id,
std::string refresh_token);
~ShellOAuth2TokenService() override;
// Returns the single instance for app_shell.
static ShellOAuth2TokenService* GetInstance();
std::string account_id() const { return account_id_; }
// Sets the current user account and refresh token.
void SetRefreshToken(const std::string& account_id,
const std::string& refresh_token);
// OAuth2TokenService:
bool RefreshTokenIsAvailable(const std::string& account_id) const override;
OAuth2AccessTokenFetcher* CreateAccessTokenFetcher(
const std::string& account_id,
net::URLRequestContextGetter* getter,
OAuth2AccessTokenConsumer* consumer) override;
net::URLRequestContextGetter* GetRequestContext() override;
private:
// Not owned.
content::BrowserContext* browser_context_;
// User account id, such as "foo@gmail.com".
std::string account_id_;
// Cached copy of an OAuth2 refresh token. Not stored on disk.
std::string refresh_token_;
DISALLOW_COPY_AND_ASSIGN(ShellOAuth2TokenService);
};
} // namespace extensions
#endif // EXTENSIONS_SHELL_BROWSER_SHELL_OAUTH2_TOKEN_SERVICE_H_