summaryrefslogtreecommitdiffstats
path: root/chrome/browser/ssl/ssl_client_auth_handler.h
diff options
context:
space:
mode:
authorjcampan@chromium.org <jcampan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-06-27 05:11:41 +0000
committerjcampan@chromium.org <jcampan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-06-27 05:11:41 +0000
commitce2b62264e87a736b81f6fad85bf97dfc0f253b1 (patch)
treed1d4e7855a35d32a0cf83a07fb6932bece688098 /chrome/browser/ssl/ssl_client_auth_handler.h
parent00692e2b916b5509bc9b18682b952e3ceb72dfb8 (diff)
downloadchromium_src-ce2b62264e87a736b81f6fad85bf97dfc0f253b1.zip
chromium_src-ce2b62264e87a736b81f6fad85bf97dfc0f253b1.tar.gz
chromium_src-ce2b62264e87a736b81f6fad85bf97dfc0f253b1.tar.bz2
A first implementation of the SSL client auth UI.This uses the Windows API that prompts the user for a cert.R=wtcBUG=http://crbug.com/318TEST=Visit a site that requires client auth. A dialog to select a certificate should be shown. Try selecting no cert. Try again this time select a cert.
Review URL: http://codereview.chromium.org/147233 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@19456 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/ssl/ssl_client_auth_handler.h')
-rw-r--r--chrome/browser/ssl/ssl_client_auth_handler.h60
1 files changed, 60 insertions, 0 deletions
diff --git a/chrome/browser/ssl/ssl_client_auth_handler.h b/chrome/browser/ssl/ssl_client_auth_handler.h
new file mode 100644
index 0000000..77b8aed
--- /dev/null
+++ b/chrome/browser/ssl/ssl_client_auth_handler.h
@@ -0,0 +1,60 @@
+// Copyright (c) 2009 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef CHROME_BROWSER_SSL_SSL_CLIENT_AUTH_HANDLER_H
+#define CHROME_BROWSER_SSL_SSL_CLIENT_AUTH_HANDLER_H
+
+#include "base/basictypes.h"
+#include "base/ref_counted.h"
+#include "net/base/ssl_cert_request_info.h"
+
+namespace net {
+class X509Certificate;
+}
+class MessageLoop;
+class URLRequest;
+
+// This class handles the approval and selection of a certificate for SSL client
+// authentication by the user.
+// It is self-owned and deletes itself when the UI reports the user selection or
+// when the URLRequest is cancelled.
+class SSLClientAuthHandler : public base::RefCounted<SSLClientAuthHandler> {
+ public:
+ SSLClientAuthHandler(URLRequest* request,
+ net::SSLCertRequestInfo* cert_request_info,
+ MessageLoop* io_loop,
+ MessageLoop* ui_loop);
+ ~SSLClientAuthHandler();
+
+ // Asks the user to select a certificate and resumes the URL request with that
+ // certificate.
+ // Should only be called on the IO thread.
+ void SelectCertificate();
+
+ // Invoked when the request associated with this handler is cancelled.
+ // Should only be called on the IO thread.
+ void OnRequestCancelled();
+
+ private:
+ // Asks the user for a cert.
+ // Called on the UI thread.
+ void DoSelectCertificate();
+
+ // Notifies that the user has selected a cert.
+ // Called on the IO thread.
+ void CertificateSelected(net::X509Certificate* cert);
+
+ // The URLRequest that triggered this client auth.
+ URLRequest* request_;
+
+ // The certs to choose from.
+ scoped_refptr<net::SSLCertRequestInfo> cert_request_info_;
+
+ MessageLoop* io_loop_;
+ MessageLoop* ui_loop_;
+
+ DISALLOW_COPY_AND_ASSIGN(SSLClientAuthHandler);
+};
+
+#endif // CHROME_BROWSER_SSL_SSL_CLIENT_AUTH_HANDLER_H