- add sources.
[platform/framework/web/crosswalk.git] / src / chrome / browser / signin / signin_promo.h
1 // Copyright 2013 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.
4
5 #ifndef CHROME_BROWSER_SIGNIN_SIGNIN_PROMO_H_
6 #define CHROME_BROWSER_SIGNIN_SIGNIN_PROMO_H_
7
8 #include <string>
9
10 #include "base/basictypes.h"
11
12 class GURL;
13 class Profile;
14
15 namespace user_prefs {
16 class PrefRegistrySyncable;
17 }
18
19 // Utility functions for sign in promos.
20 namespace signin {
21
22 enum Source {
23   SOURCE_START_PAGE = 0, // This must be first.
24   SOURCE_NTP_LINK,
25   SOURCE_MENU,
26   SOURCE_SETTINGS,
27   SOURCE_EXTENSION_INSTALL_BUBBLE,
28   SOURCE_WEBSTORE_INSTALL,
29   SOURCE_APP_LAUNCHER,
30   SOURCE_APPS_PAGE_LINK,
31   SOURCE_BOOKMARK_BUBBLE,
32   SOURCE_AVATAR_BUBBLE_SIGN_IN,
33   SOURCE_AVATAR_BUBBLE_ADD_ACCOUNT,
34   SOURCE_UNKNOWN, // This must be last.
35 };
36
37 // Returns true if the sign in promo should be visible.
38 // |profile| is the profile of the tab the promo would be shown on.
39 bool ShouldShowPromo(Profile* profile);
40
41 // Returns true if we should show the sign in promo at startup.
42 bool ShouldShowPromoAtStartup(Profile* profile, bool is_new_profile);
43
44 // Called when the sign in promo has been shown so that we can keep track
45 // of the number of times we've displayed it.
46 void DidShowPromoAtStartup(Profile* profile);
47
48 // Registers the fact that the user has skipped the sign in promo.
49 void SetUserSkippedPromo(Profile* profile);
50
51 // Gets the sign in landing page URL.
52 GURL GetLandingURL(const char* option, int value);
53
54 // Returns the sign in promo URL wth the given arguments in the query.
55 // |source| identifies from where the sign in promo is being called, and is
56 // used to record sync promo UMA stats in the context of the source.
57 // |auto_close| whether to close the sign in promo automatically when done.
58 GURL GetPromoURL(Source source, bool auto_close);
59
60 // Gets the next page URL from the query portion of the sign in promo URL.
61 GURL GetNextPageURLForPromoURL(const GURL& url);
62
63 // Gets the source from the query portion of the sign in promo URL.
64 // The source identifies from where the sign in promo was opened.
65 Source GetSourceForPromoURL(const GURL& url);
66
67 // Returns true if the auto_close parameter in the given URL is set to true.
68 bool IsAutoCloseEnabledInURL(const GURL& url);
69
70 // Returns true if the given URL is the standard continue URL used with the
71 // sync promo when the web-based flow is enabled.  The query parameters
72 // of the URL are ignored for this comparison.
73 bool IsContinueUrlForWebBasedSigninFlow(const GURL& url);
74
75 // Forces UseWebBasedSigninFlow() to return true when set; used in tests only.
76 void ForceWebBasedSigninFlowForTesting(bool force);
77
78 // Registers the preferences the Sign In Promo needs.
79 void RegisterProfilePrefs(user_prefs::PrefRegistrySyncable* registry);
80
81 }  // namespace signin
82
83 #endif  // CHROME_BROWSER_SIGNIN_SIGNIN_PROMO_H_