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 CONTENT_BROWSER_SSL_SSL_ERROR_HANDLER_H_
6 #define CONTENT_BROWSER_SSL_SSL_ERROR_HANDLER_H_
10 #include "base/basictypes.h"
11 #include "base/memory/ref_counted.h"
12 #include "base/memory/weak_ptr.h"
13 #include "content/common/content_export.h"
14 #include "content/public/browser/global_request_id.h"
15 #include "googleurl/src/gurl.h"
16 #include "webkit/glue/resource_type.h"
25 class ResourceDispatcherHostImpl
;
26 class SSLCertErrorHandler
;
29 // An SSLErrorHandler carries information from the IO thread to the UI thread
30 // and is dispatched to the appropriate SSLManager when it arrives on the
31 // UI thread. Subclasses should override the OnDispatched/OnDispatchFailed
32 // methods to implement the actions that should be taken on the UI thread.
33 // These methods can call the different convenience methods ContinueRequest/
34 // CancelRequest to perform any required action on the net::URLRequest the
35 // ErrorHandler was created with.
39 // If you are not doing anything in OnDispatched/OnDispatchFailed, make sure
40 // you call TakeNoAction(). This is necessary for ensuring the instance is
43 class SSLErrorHandler
: public base::RefCountedThreadSafe
<SSLErrorHandler
> {
45 // Delegate functions must be called from IO thread. All functions accept
46 // |id| as the first argument. |id| is a copy of the second argument of
47 // SSLManager::OnSSLCertificateError() and represents the request.
48 // Finally, CancelSSLRequest() or ContinueSSLRequest() will be called after
49 // SSLErrorHandler makes a decision on the SSL error.
50 class CONTENT_EXPORT Delegate
{
52 // Called when SSLErrorHandler decides to cancel the request because of
54 virtual void CancelSSLRequest(const GlobalRequestID
& id
,
56 const net::SSLInfo
* ssl_info
) = 0;
58 // Called when SSLErrorHandler decides to continue the request despite the
60 virtual void ContinueSSLRequest(const GlobalRequestID
& id
) = 0;
63 virtual ~Delegate() {}
66 virtual SSLCertErrorHandler
* AsSSLCertErrorHandler();
68 // Find the appropriate SSLManager for the net::URLRequest and begin handling
74 // Available on either thread.
75 const GURL
& request_url() const { return request_url_
; }
77 // Available on either thread.
78 ResourceType::Type
resource_type() const { return resource_type_
; }
80 // Cancels the associated net::URLRequest.
81 // This method can be called from OnDispatchFailed and OnDispatched.
82 CONTENT_EXPORT
void CancelRequest();
84 // Continue the net::URLRequest ignoring any previous errors. Note that some
85 // errors cannot be ignored, in which case this will result in the request
87 // This method can be called from OnDispatchFailed and OnDispatched.
88 void ContinueRequest();
90 // Cancels the associated net::URLRequest and mark it as denied. The renderer
91 // processes such request in a special manner, optionally replacing them
92 // with alternate content (typically frames content is replaced with a
94 // This method can be called from OnDispatchFailed and OnDispatched.
97 // Does nothing on the net::URLRequest but ensures the current instance ref
98 // count is decremented appropriately. Subclasses that do not want to
99 // take any specific actions in their OnDispatched/OnDispatchFailed should
103 int render_process_id() const { return render_process_id_
; }
104 int render_view_id() const { return render_view_id_
; }
107 friend class base::RefCountedThreadSafe
<SSLErrorHandler
>;
109 // Construct on the IO thread.
110 SSLErrorHandler(const base::WeakPtr
<Delegate
>& delegate
,
111 const GlobalRequestID
& id
,
112 ResourceType::Type resource_type
,
114 int render_process_id
,
117 virtual ~SSLErrorHandler();
119 // The following 2 methods are the methods subclasses should implement.
120 virtual void OnDispatchFailed();
122 // Can use the manager_ member.
123 virtual void OnDispatched();
125 // Should only be accessed on the UI thread.
126 SSLManager
* manager_
; // Our manager.
128 // The id of the request associated with this object.
129 // Should only be accessed from the IO thread.
130 GlobalRequestID request_id_
;
132 // The delegate we are associated with.
133 base::WeakPtr
<Delegate
> delegate_
;
136 // Completes the CancelRequest operation on the IO thread.
137 // Call on the IO thread.
138 void CompleteCancelRequest(int error
);
140 // Completes the ContinueRequest operation on the IO thread.
142 // Call on the IO thread.
143 void CompleteContinueRequest();
145 // Derefs this instance.
146 // Call on the IO thread.
147 void CompleteTakeNoAction();
149 // We use these members to find the correct SSLManager when we arrive on
151 int render_process_id_
;
154 // The URL that we requested.
155 // This read-only member can be accessed on any thread.
156 const GURL request_url_
;
158 // What kind of resource is associated with the requested that generated
160 // This read-only member can be accessed on any thread.
161 const ResourceType::Type resource_type_
;
163 // A flag to make sure we notify the net::URLRequest exactly once.
164 // Should only be accessed on the IO thread
165 bool request_has_been_notified_
;
167 DISALLOW_COPY_AND_ASSIGN(SSLErrorHandler
);
170 } // namespace content
172 #endif // CONTENT_BROWSER_SSL_SSL_ERROR_HANDLER_H_