Home | History | Annotate | Download | only in gaia
      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 // A GoogleServiceAuthError is immutable, plain old data representing an
      6 // error from an attempt to authenticate with a Google service.
      7 // It could be from Google Accounts itself, or any service using Google
      8 // Accounts (e.g expired credentials).  It may contain additional data such as
      9 // captcha or OTP challenges.
     10 
     11 // A GoogleServiceAuthError without additional data is just a State, defined
     12 // below. A case could be made to have this relation implicit, to allow raising
     13 // error events concisely by doing OnAuthError(GoogleServiceAuthError::NONE),
     14 // for example. But the truth is this class is ever so slightly more than a
     15 // transparent wrapper around 'State' due to additional Captcha data
     16 // (e.g consider operator=), and this would violate the style guide. Thus,
     17 // you must explicitly use the constructor when all you have is a State.
     18 // The good news is the implementation nests the enum inside a class, so you
     19 // may forward declare and typedef GoogleServiceAuthError to something shorter
     20 // in the comfort of your own translation unit.
     21 
     22 #ifndef GOOGLE_APIS_GAIA_GOOGLE_SERVICE_AUTH_ERROR_H_
     23 #define GOOGLE_APIS_GAIA_GOOGLE_SERVICE_AUTH_ERROR_H_
     24 
     25 #include <string>
     26 
     27 #include "url/gurl.h"
     28 
     29 namespace base {
     30 class DictionaryValue;
     31 }
     32 
     33 class GoogleServiceAuthError {
     34  public:
     35   //
     36   // These enumerations are referenced by integer value in HTML login code and
     37   // in UMA histograms. Do not change the numeric values.
     38   //
     39   enum State {
     40     // The user is authenticated.
     41     NONE = 0,
     42 
     43     // The credentials supplied to GAIA were either invalid, or the locally
     44     // cached credentials have expired.
     45     INVALID_GAIA_CREDENTIALS = 1,
     46 
     47     // The GAIA user is not authorized to use the service.
     48     USER_NOT_SIGNED_UP = 2,
     49 
     50     // Could not connect to server to verify credentials. This could be in
     51     // response to either failure to connect to GAIA or failure to connect to
     52     // the service needing GAIA tokens during authentication.
     53     CONNECTION_FAILED = 3,
     54 
     55     // The user needs to satisfy a CAPTCHA challenge to unlock their account.
     56     // If no other information is available, this can be resolved by visiting
     57     // https://accounts.google.com/DisplayUnlockCaptcha. Otherwise, captcha()
     58     // will provide details about the associated challenge.
     59     CAPTCHA_REQUIRED = 4,
     60 
     61     // The user account has been deleted.
     62     ACCOUNT_DELETED = 5,
     63 
     64     // The user account has been disabled.
     65     ACCOUNT_DISABLED = 6,
     66 
     67     // The service is not available; try again later.
     68     SERVICE_UNAVAILABLE = 7,
     69 
     70     // The password is valid but we need two factor to get a token.
     71     TWO_FACTOR = 8,
     72 
     73     // The requestor of the authentication step cancelled the request
     74     // prior to completion.
     75     REQUEST_CANCELED = 9,
     76 
     77     // The user has provided a HOSTED account, when this service requires
     78     // a GOOGLE account.
     79     HOSTED_NOT_ALLOWED = 10,
     80 
     81     // Indicates the service responded to a request, but we cannot
     82     // interpret the response.
     83     UNEXPECTED_SERVICE_RESPONSE = 11,
     84 
     85     // Indicates the service responded and response carried details of the
     86     // application error.
     87     SERVICE_ERROR = 12,
     88 
     89     // The number of known error states.
     90     NUM_STATES = 13,
     91   };
     92 
     93   // Additional data for CAPTCHA_REQUIRED errors.
     94   struct Captcha {
     95     Captcha();
     96     Captcha(const std::string& token,
     97             const GURL& audio,
     98             const GURL& img,
     99             const GURL& unlock,
    100             int width,
    101             int height);
    102     ~Captcha();
    103     // For test only.
    104     bool operator==(const Captcha &b) const;
    105 
    106     std::string token;  // Globally identifies the specific CAPTCHA challenge.
    107     GURL audio_url;     // The CAPTCHA audio to use instead of image.
    108     GURL image_url;     // The CAPTCHA image to show the user.
    109     GURL unlock_url;    // Pretty unlock page containing above captcha.
    110     int image_width;    // Width of captcha image.
    111     int image_height;   // Height of capture image.
    112   };
    113 
    114   // Additional data for TWO_FACTOR errors.
    115   struct SecondFactor {
    116     SecondFactor();
    117     SecondFactor(const std::string& token,
    118                  const std::string& prompt,
    119                  const std::string& alternate,
    120                  int length);
    121     ~SecondFactor();
    122     // For test only.
    123     bool operator==(const SecondFactor &b) const;
    124 
    125     // Globally identifies the specific second-factor challenge.
    126     std::string token;
    127     // Localised prompt text, eg Enter the verification code sent to your
    128     // phone number ending in XXX.
    129     std::string prompt_text;
    130     // Localized text describing an alternate option, eg Get a verification
    131     // code in a text message.
    132     std::string alternate_text;
    133     // Character length for the challenge field.
    134     int field_length;
    135   };
    136 
    137   // For test only.
    138   bool operator==(const GoogleServiceAuthError &b) const;
    139 
    140   // Construct a GoogleServiceAuthError from a State with no additional data.
    141   explicit GoogleServiceAuthError(State s);
    142 
    143   // Construct a GoogleServiceAuthError from a network error.
    144   // It will be created with CONNECTION_FAILED set.
    145   static GoogleServiceAuthError FromConnectionError(int error);
    146 
    147   // Construct a CAPTCHA_REQUIRED error with CAPTCHA challenge data from the
    148   // the ClientLogin endpoint.
    149   // TODO(rogerta): once ClientLogin is no longer used, may be able to get
    150   // rid of this function.
    151   static GoogleServiceAuthError FromClientLoginCaptchaChallenge(
    152       const std::string& captcha_token,
    153       const GURL& captcha_image_url,
    154       const GURL& captcha_unlock_url);
    155 
    156   // Construct a SERVICE_ERROR error, e.g. invalid client ID, with an
    157   // |error_message| which provides more information about the service error.
    158   static GoogleServiceAuthError FromServiceError(
    159       const std::string& error_message);
    160 
    161   // Construct an UNEXPECTED_SERVICE_RESPONSE error, with an |error_message|
    162   // detailing the problems with the response.
    163   static GoogleServiceAuthError FromUnexpectedServiceResponse(
    164       const std::string& error_message);
    165 
    166   // Provided for convenience for clients needing to reset an instance to NONE.
    167   // (avoids err_ = GoogleServiceAuthError(GoogleServiceAuthError::NONE), due
    168   // to explicit class and State enum relation. Note: shouldn't be inlined!
    169   static GoogleServiceAuthError AuthErrorNone();
    170 
    171   // The error information.
    172   State state() const;
    173   const Captcha& captcha() const;
    174   const SecondFactor& second_factor() const;
    175   int network_error() const;
    176   const std::string& token() const;
    177   const std::string& error_message() const;
    178 
    179   // Returns info about this object in a dictionary.  Caller takes
    180   // ownership of returned dictionary.
    181   base::DictionaryValue* ToValue() const;
    182 
    183   // Returns a message describing the error.
    184   std::string ToString() const;
    185 
    186  private:
    187   GoogleServiceAuthError(State s, int error);
    188 
    189   // Construct a GoogleServiceAuthError from |state| and |error_message|.
    190   GoogleServiceAuthError(State state, const std::string& error_message);
    191 
    192   explicit GoogleServiceAuthError(const std::string& error_message);
    193 
    194   GoogleServiceAuthError(State s, const std::string& captcha_token,
    195                          const GURL& captcha_audio_url,
    196                          const GURL& captcha_image_url,
    197                          const GURL& captcha_unlock_url,
    198                          int image_width,
    199                          int image_height);
    200 
    201   GoogleServiceAuthError(State s, const std::string& captcha_token,
    202                          const std::string& prompt_text,
    203                          const std::string& alternate_text,
    204                          int field_length);
    205 
    206   State state_;
    207   Captcha captcha_;
    208   SecondFactor second_factor_;
    209   int network_error_;
    210   std::string error_message_;
    211 };
    212 
    213 #endif  // GOOGLE_APIS_GAIA_GOOGLE_SERVICE_AUTH_ERROR_H_
    214