• 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 #include "net/http/http_auth_handler.h"
6 
7 #include "base/bind.h"
8 #include "base/bind_helpers.h"
9 #include "base/logging.h"
10 #include "net/base/net_errors.h"
11 #include "net/http/http_auth_challenge_tokenizer.h"
12 
13 namespace net {
14 
HttpAuthHandler()15 HttpAuthHandler::HttpAuthHandler()
16     : auth_scheme_(HttpAuth::AUTH_SCHEME_MAX),
17       score_(-1),
18       target_(HttpAuth::AUTH_NONE),
19       properties_(-1) {
20 }
21 
~HttpAuthHandler()22 HttpAuthHandler::~HttpAuthHandler() {
23 }
24 
InitFromChallenge(HttpAuthChallengeTokenizer * challenge,HttpAuth::Target target,const GURL & origin,const BoundNetLog & net_log)25 bool HttpAuthHandler::InitFromChallenge(
26     HttpAuthChallengeTokenizer* challenge,
27     HttpAuth::Target target,
28     const GURL& origin,
29     const BoundNetLog& net_log) {
30   origin_ = origin;
31   target_ = target;
32   score_ = -1;
33   properties_ = -1;
34   net_log_ = net_log;
35 
36   auth_challenge_ = challenge->challenge_text();
37   bool ok = Init(challenge);
38 
39   // Init() is expected to set the scheme, realm, score, and properties.  The
40   // realm may be empty.
41   DCHECK(!ok || score_ != -1);
42   DCHECK(!ok || properties_ != -1);
43   DCHECK(!ok || auth_scheme_ != HttpAuth::AUTH_SCHEME_MAX);
44 
45   return ok;
46 }
47 
48 namespace {
49 
EventTypeFromAuthTarget(HttpAuth::Target target)50 NetLog::EventType EventTypeFromAuthTarget(HttpAuth::Target target) {
51   switch (target) {
52     case HttpAuth::AUTH_PROXY:
53       return NetLog::TYPE_AUTH_PROXY;
54     case HttpAuth::AUTH_SERVER:
55       return NetLog::TYPE_AUTH_SERVER;
56     default:
57       NOTREACHED();
58       return NetLog::TYPE_CANCELLED;
59   }
60 }
61 
62 }  // namespace
63 
GenerateAuthToken(const AuthCredentials * credentials,const HttpRequestInfo * request,const CompletionCallback & callback,std::string * auth_token)64 int HttpAuthHandler::GenerateAuthToken(
65     const AuthCredentials* credentials, const HttpRequestInfo* request,
66     const CompletionCallback& callback, std::string* auth_token) {
67   // TODO(cbentzel): Enforce non-NULL callback after cleaning up SocketStream.
68   DCHECK(request);
69   DCHECK(credentials != NULL || AllowsDefaultCredentials());
70   DCHECK(auth_token != NULL);
71   DCHECK(callback_.is_null());
72   callback_ = callback;
73   net_log_.BeginEvent(EventTypeFromAuthTarget(target_));
74   int rv = GenerateAuthTokenImpl(
75       credentials, request,
76       base::Bind(&HttpAuthHandler::OnGenerateAuthTokenComplete,
77                  base::Unretained(this)),
78       auth_token);
79   if (rv != ERR_IO_PENDING)
80     FinishGenerateAuthToken();
81   return rv;
82 }
83 
NeedsIdentity()84 bool HttpAuthHandler::NeedsIdentity() {
85   return true;
86 }
87 
AllowsDefaultCredentials()88 bool HttpAuthHandler::AllowsDefaultCredentials() {
89   return false;
90 }
91 
AllowsExplicitCredentials()92 bool HttpAuthHandler::AllowsExplicitCredentials() {
93   return true;
94 }
95 
OnGenerateAuthTokenComplete(int rv)96 void HttpAuthHandler::OnGenerateAuthTokenComplete(int rv) {
97   CompletionCallback callback = callback_;
98   FinishGenerateAuthToken();
99   if (!callback.is_null())
100     callback.Run(rv);
101 }
102 
FinishGenerateAuthToken()103 void HttpAuthHandler::FinishGenerateAuthToken() {
104   // TOOD(cbentzel): Should this be done in OK case only?
105   net_log_.EndEvent(EventTypeFromAuthTarget(target_));
106   callback_.Reset();
107 }
108 
109 }  // namespace net
110