Merge Chromium + Blink git repositories
[chromium-blink-merge.git] / content / public / browser / access_token_store.h
blobbd130144c6c41b7421ebdf16767fa99d03690783
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 // Defines the Geolocation access token store, and associated factory function.
6 // An access token store is responsible for providing the API to persist
7 // access tokens, one at a time, and to load them back on mass.
8 // The API is a little more complex than one might wish, due to the need for
9 // prefs access to happen asynchronously on the UI thread.
10 // This API is provided as abstract base classes to allow mocking and testing
11 // of clients, without dependency on browser process singleton objects etc.
13 #ifndef CONTENT_PUBLIC_BROWSER_ACCESS_TOKEN_STORE_H_
14 #define CONTENT_PUBLIC_BROWSER_ACCESS_TOKEN_STORE_H_
16 #include <map>
18 #include "base/callback.h"
19 #include "base/memory/ref_counted.h"
20 #include "base/strings/string16.h"
21 #include "content/common/content_export.h"
22 #include "url/gurl.h"
24 class GURL;
26 namespace net {
27 class URLRequestContextGetter;
30 namespace content {
32 // Provides storage for the access token used in the network request.
33 class AccessTokenStore : public base::RefCountedThreadSafe<AccessTokenStore> {
34 public:
35 // Map of server URLs to associated access token.
36 typedef std::map<GURL, base::string16> AccessTokenSet;
37 typedef base::Callback<void(AccessTokenSet, net::URLRequestContextGetter*)>
38 LoadAccessTokensCallbackType;
40 // |callback| will be invoked once per LoadAccessTokens call, after existing
41 // access tokens have been loaded from persistent store. As a convenience the
42 // URLRequestContextGetter is also supplied as an argument in |callback|, as
43 // in Chrome the call to obtain this must also be performed on the UI thread
44 // so it is efficient to piggyback it onto this request.
45 // Takes ownership of |callback|.
46 virtual void LoadAccessTokens(
47 const LoadAccessTokensCallbackType& callback) = 0;
49 virtual void SaveAccessToken(
50 const GURL& server_url, const base::string16& access_token) = 0;
52 protected:
53 friend class base::RefCountedThreadSafe<AccessTokenStore>;
54 CONTENT_EXPORT AccessTokenStore() {}
55 CONTENT_EXPORT virtual ~AccessTokenStore() {}
58 } // namespace content
60 #endif // CONTENT_PUBLIC_BROWSER_ACCESS_TOKEN_STORE_H_