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 GOOGLE_APIS_GAIA_GAIA_AUTH_UTIL_H_
6 #define GOOGLE_APIS_GAIA_GAIA_AUTH_UTIL_H_
16 // Perform basic canonicalization of |email_address|, taking into account that
17 // gmail does not consider '.' or caps inside a username to matter. It also
18 // ignores everything after a '+'. For example, c.masone+abc@gmail.com ==
19 // cMaSone@gmail.com, per
20 // http://mail.google.com/support/bin/answer.py?hl=en&ctx=mail&answer=10313#
21 std::string CanonicalizeEmail(const std::string& email_address);
23 // Returns the canonical form of the given domain.
24 std::string CanonicalizeDomain(const std::string& domain);
26 // Sanitize emails. Currently, it only ensures all emails have a domain by
27 // adding gmail.com if no domain is present.
28 std::string SanitizeEmail(const std::string& email_address);
30 // Returns true if the two specified email addresses are the same. Both
31 // addresses are first sanitized and then canoncialized before comparing.
32 bool AreEmailsSame(const std::string& email1, const std::string& email2);
34 // Extract the domain part from the canonical form of the given email.
35 std::string ExtractDomainName(const std::string& email);
37 bool IsGaiaSignonRealm(const GURL& url);
39 // Parses JSON data returned by /ListAccounts call, returning a vector of
40 // email/valid pairs. An email addresses is considered valid if a passive
41 // login would succeed (i.e. the user does not need to reauthenticate).
42 // If there an error parsing the JSON, then false is returned.
43 bool ParseListAccountsData(
44 const std::string& data,
45 std::vector<std::pair<std::string, bool> >* accounts);
49 #endif // GOOGLE_APIS_GAIA_GAIA_AUTH_UTIL_H_