• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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.
4 
5 #ifndef CHROME_BROWSER_SIGNIN_SIGNIN_INTERNALS_UTIL_H_
6 #define CHROME_BROWSER_SIGNIN_SIGNIN_INTERNALS_UTIL_H_
7 
8 #include <map>
9 #include <string>
10 
11 #include "base/memory/scoped_ptr.h"
12 #include "base/values.h"
13 
14 namespace signin_internals_util {
15 
16 // Preference prefixes for signin and token values.
17 extern const char kSigninPrefPrefix[];
18 extern const char kTokenPrefPrefix[];
19 
20 // The length of strings returned by GetTruncatedHash() below.
21 const size_t kTruncateTokenStringLength = 6;
22 
23 // Helper enums to access fields from SigninStatus (declared below).
24 enum {
25   SIGNIN_FIELDS_BEGIN = 0,
26   UNTIMED_FIELDS_BEGIN = SIGNIN_FIELDS_BEGIN
27 };
28 
29 enum UntimedSigninStatusField {
30   USERNAME = UNTIMED_FIELDS_BEGIN,
31   SID,
32   LSID,
33   UNTIMED_FIELDS_END
34 };
35 
36 enum {
37   UNTIMED_FIELDS_COUNT = UNTIMED_FIELDS_END - UNTIMED_FIELDS_BEGIN,
38   TIMED_FIELDS_BEGIN = UNTIMED_FIELDS_END
39 };
40 
41 enum TimedSigninStatusField {
42   SIGNIN_TYPE = TIMED_FIELDS_BEGIN,
43   CLIENT_LOGIN_STATUS,
44   OAUTH_LOGIN_STATUS,
45   GET_USER_INFO_STATUS,
46   UBER_TOKEN_STATUS,
47   MERGE_SESSION_STATUS,
48   TIMED_FIELDS_END
49 };
50 
51 enum {
52   TIMED_FIELDS_COUNT = TIMED_FIELDS_END - TIMED_FIELDS_BEGIN,
53   SIGNIN_FIELDS_END = TIMED_FIELDS_END,
54   SIGNIN_FIELDS_COUNT = SIGNIN_FIELDS_END - SIGNIN_FIELDS_BEGIN
55 };
56 
57 // Encapsulates diagnostic information about tokens for different services.
58 // Note that although SigninStatus contains a map of service names to token
59 // values, we replicate the service name within this struct for a cleaner
60 // serialization (with ToValue()).
61 struct TokenInfo {
62   std::string truncated_token;  // The hashed and truncated token.
63   std::string status;  // Status of the last token fetch.
64   std::string time;  // Timestamp of the last token fetch
65   int64 time_internal;  // Same as |time|, but in base::Time internal format.
66   std::string service;  // The service that this token is for.
67 
68   TokenInfo(const std::string& truncated_token,
69             const std::string& status,
70             const std::string& time,
71             const int64& time_internal,
72             const std::string& service);
73   TokenInfo();
74   ~TokenInfo();
75 
76   DictionaryValue* ToValue();
77 };
78 
79 // Associates a service name with its token information.
80 typedef std::map<std::string, TokenInfo> TokenInfoMap;
81 
82 // Returns the root preference path for the service. The path should be
83 // qualified with one of .value, .status or .time to get the respective
84 // full preference path names.
85 std::string TokenPrefPath(const std::string& service_name);
86 
87 // Many values in SigninStatus are also associated with a timestamp.
88 // This makes it easier to keep values and their associated times together.
89 typedef std::pair<std::string, std::string> TimedSigninStatusValue;
90 
91 // Returns the name of a SigninStatus field.
92 std::string SigninStatusFieldToString(UntimedSigninStatusField field);
93 std::string SigninStatusFieldToString(TimedSigninStatusField field);
94 
95 // Encapsulates both authentication and token related information. Used
96 // by SigninInternals to maintain information that needs to be shown in
97 // the about:signin-internals page.
98 struct SigninStatus {
99   std::vector<std::string> untimed_signin_fields;
100   std::vector<TimedSigninStatusValue> timed_signin_fields;
101   TokenInfoMap token_info_map;
102 
103   SigninStatus();
104   ~SigninStatus();
105 
106   // Returns a dictionary with the following form:
107   // { "signin_info" :
108   //     [ {"title": "Basic Information",
109   //        "data": [List of {"label" : "foo-field", "value" : "foo"} elems]
110   //       },
111   //       { "title": "Detailed Information",
112   //        "data": [List of {"label" : "foo-field", "value" : "foo"} elems]
113   //       }],
114   //   "token_info" :
115   //     [ List of {"name": "foo-name", "token" : "foo-token",
116   //                 "status": "foo_stat", "time" : "foo_time"} elems]
117   //  }
118   scoped_ptr<DictionaryValue> ToValue();
119 };
120 
121 // An Observer class for authentication and token diagnostic information.
122 class SigninDiagnosticsObserver {
123  public:
124   // Credentials and signin related changes.
NotifySigninValueChanged(const UntimedSigninStatusField & field,const std::string & value)125   virtual void NotifySigninValueChanged(const UntimedSigninStatusField& field,
126                                         const std::string& value) {}
NotifySigninValueChanged(const TimedSigninStatusField & field,const std::string & value)127   virtual void NotifySigninValueChanged(const TimedSigninStatusField& field,
128                                         const std::string& value) {}
129   // OAuth tokens related changes.
NotifyTokenReceivedSuccess(const std::string & token_name,const std::string & token,bool update_time)130   virtual void NotifyTokenReceivedSuccess(const std::string& token_name,
131                                           const std::string& token,
132                                           bool update_time) {}
NotifyTokenReceivedFailure(const std::string & token_name,const std::string & error)133   virtual void NotifyTokenReceivedFailure(const std::string& token_name,
134                                           const std::string& error) {}
NotifyClearStoredToken(const std::string & token_name)135   virtual void NotifyClearStoredToken(const std::string& token_name) {}};
136 
137 // Gets the first 6 hex characters of the SHA256 hash of the passed in string.
138 // These are enough to perform equality checks across a single users tokens,
139 // while preventing outsiders from reverse-engineering the actual token from
140 // the displayed value.
141 // Note that for readability (in about:signin-internals), an empty string
142 // is not hashed, but simply returned as an empty string.
143 std::string GetTruncatedHash(const std::string& str);
144 
145 } // namespace signin_internals_util
146 
147 #endif  // CHROME_BROWSER_SIGNIN_SIGNIN_INTERNALS_UTIL_H_
148