Disable view source for Developer Tools.
[chromium-blink-merge.git] / chrome / browser / profiles / profile_downloader.h
blob8faf26d6ef0e047fbbe9bdb6a33dc7eedf4b3a6c
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 #ifndef CHROME_BROWSER_PROFILES_PROFILE_DOWNLOADER_H_
6 #define CHROME_BROWSER_PROFILES_PROFILE_DOWNLOADER_H_
8 #include <string>
10 #include "base/basictypes.h"
11 #include "base/gtest_prod_util.h"
12 #include "base/memory/scoped_ptr.h"
13 #include "base/strings/string16.h"
14 #include "chrome/browser/image_decoder.h"
15 #include "google_apis/gaia/oauth2_token_service.h"
16 #include "net/url_request/url_fetcher_delegate.h"
17 #include "third_party/skia/include/core/SkBitmap.h"
18 #include "url/gurl.h"
20 class ProfileDownloaderDelegate;
21 class OAuth2AccessTokenFetcher;
23 namespace net {
24 class URLFetcher;
25 } // namespace net
27 // Downloads user profile information. The profile picture is decoded in a
28 // sandboxed process.
29 class ProfileDownloader : public net::URLFetcherDelegate,
30 public ImageDecoder::Delegate,
31 public OAuth2TokenService::Observer,
32 public OAuth2TokenService::Consumer {
33 public:
34 enum PictureStatus {
35 PICTURE_SUCCESS,
36 PICTURE_FAILED,
37 PICTURE_DEFAULT,
38 PICTURE_CACHED,
41 explicit ProfileDownloader(ProfileDownloaderDelegate* delegate);
42 virtual ~ProfileDownloader();
44 // Starts downloading profile information if the necessary authorization token
45 // is ready. If not, subscribes to token service and starts fetching if the
46 // token is available. Should not be called more than once.
47 virtual void Start();
49 // Starts downloading profile information if the necessary authorization token
50 // is ready. If not, subscribes to token service and starts fetching if the
51 // token is available. Should not be called more than once.
52 virtual void StartForAccount(const std::string& account_id);
54 // On successful download this returns the full name of the user. For example
55 // "Pat Smith".
56 virtual base::string16 GetProfileFullName() const;
58 // On successful download this returns the given name of the user. For example
59 // if the name is "Pat Smith", the given name is "Pat".
60 virtual base::string16 GetProfileGivenName() const;
62 // On successful download this returns G+ locale preference of the user.
63 virtual std::string GetProfileLocale() const;
65 // On successful download this returns the profile picture of the user.
66 // For users with no profile picture set (that is, they have the default
67 // profile picture) this will return an Null bitmap.
68 virtual SkBitmap GetProfilePicture() const;
70 // Gets the profile picture status.
71 virtual PictureStatus GetProfilePictureStatus() const;
73 // Gets the URL for the profile picture. This can be cached so that the same
74 // picture is not downloaded multiple times. This value should only be used
75 // when the picture status is PICTURE_SUCCESS.
76 virtual std::string GetProfilePictureURL() const;
78 private:
79 friend class ProfileDownloaderTest;
80 FRIEND_TEST_ALL_PREFIXES(ProfileDownloaderTest, ParseData);
81 FRIEND_TEST_ALL_PREFIXES(ProfileDownloaderTest, DefaultURL);
83 // Overriden from net::URLFetcherDelegate:
84 virtual void OnURLFetchComplete(const net::URLFetcher* source) OVERRIDE;
86 // Overriden from ImageDecoder::Delegate:
87 virtual void OnImageDecoded(const ImageDecoder* decoder,
88 const SkBitmap& decoded_image) OVERRIDE;
89 virtual void OnDecodeImageFailed(const ImageDecoder* decoder) OVERRIDE;
91 // Overriden from OAuth2TokenService::Observer:
92 virtual void OnRefreshTokenAvailable(const std::string& account_id) OVERRIDE;
94 // Overriden from OAuth2TokenService::Consumer:
95 virtual void OnGetTokenSuccess(const OAuth2TokenService::Request* request,
96 const std::string& access_token,
97 const base::Time& expiration_time) OVERRIDE;
98 virtual void OnGetTokenFailure(const OAuth2TokenService::Request* request,
99 const GoogleServiceAuthError& error) OVERRIDE;
101 // Parses the entry response and gets the name, profile image URL and locale.
102 // |data| should be the JSON formatted data return by the response.
103 // Returns false to indicate a parsing error.
104 static bool ParseProfileJSON(const std::string& data,
105 base::string16* full_name,
106 base::string16* given_name,
107 std::string* url,
108 int image_size,
109 std::string* profile_locale);
110 // Returns true if the image url is url of the default profile picture.
111 static bool IsDefaultProfileImageURL(const std::string& url);
113 // Issues the first request to get user profile image.
114 void StartFetchingImage();
116 // Gets the authorization header.
117 const char* GetAuthorizationHeader() const;
119 // Starts fetching OAuth2 access token. This is needed before the GAIA info
120 // can be downloaded.
121 void StartFetchingOAuth2AccessToken();
123 ProfileDownloaderDelegate* delegate_;
124 std::string account_id_;
125 std::string auth_token_;
126 scoped_ptr<net::URLFetcher> user_entry_fetcher_;
127 scoped_ptr<net::URLFetcher> profile_image_fetcher_;
128 scoped_ptr<OAuth2TokenService::Request> oauth2_access_token_request_;
129 base::string16 profile_full_name_;
130 base::string16 profile_given_name_;
131 std::string profile_locale_;
132 SkBitmap profile_picture_;
133 PictureStatus picture_status_;
134 std::string picture_url_;
136 DISALLOW_COPY_AND_ASSIGN(ProfileDownloader);
139 #endif // CHROME_BROWSER_PROFILES_PROFILE_DOWNLOADER_H_