Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(19)

Side by Side Diff: chrome/browser/renderer_host/x509_user_cert_resource_handler.cc

Issue 271112: Adds support for the <keygen> tag for client certificate enrollment... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: Upload before checkin Created 11 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « chrome/browser/renderer_host/x509_user_cert_resource_handler.h ('k') | chrome/chrome.gyp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Property Changes:
Added: svn:eol-style
+ LF
OLDNEW
(Empty)
1 // Copyright (c) 2009 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 "chrome/browser/renderer_host/x509_user_cert_resource_handler.h"
6
7 #include "base/string_util.h"
8 #include "chrome/browser/browser_process.h"
9 #include "chrome/browser/chrome_thread.h"
10 #include "chrome/browser/download/download_file.h"
11 #include "chrome/browser/renderer_host/resource_dispatcher_host.h"
12 #include "chrome/browser/renderer_host/resource_dispatcher_host_request_info.h"
13 #include "chrome/common/url_constants.h"
14 #include "net/base/cert_database.h"
15 #include "net/base/io_buffer.h"
16 #include "net/base/mime_sniffer.h"
17 #include "net/base/mime_util.h"
18 #include "net/http/http_response_headers.h"
19
20 X509UserCertResourceHandler::X509UserCertResourceHandler(
21 ResourceDispatcherHost* host, URLRequest* request)
22 : host_(host),
23 request_(request),
24 content_length_(0),
25 buffer_(new DownloadBuffer),
26 read_buffer_(NULL),
27 resource_buffer_(NULL) {
28 }
29
30 bool X509UserCertResourceHandler::OnRequestRedirected(int request_id,
31 const GURL& url,
32 ResourceResponse* resp,
33 bool* defer) {
34 url_ = url;
35 return true;
36 }
37
38 bool X509UserCertResourceHandler::OnResponseStarted(int request_id,
39 ResourceResponse* resp) {
40 return (resp->response_head.mime_type == "application/x-x509-user-cert");
41 }
42
43 bool X509UserCertResourceHandler::OnWillRead(int request_id,
44 net::IOBuffer** buf,
45 int* buf_size,
46 int min_size) {
47 // TODO(gauravsh): Should we use 'min_size' here?
48 DCHECK(buf && buf_size);
49 if (!read_buffer_) {
50 read_buffer_ = new net::IOBuffer(kReadBufSize);
51 }
52 *buf = read_buffer_.get();
53 *buf_size = kReadBufSize;
54
55 return true;
56 }
57
58 bool X509UserCertResourceHandler::OnReadCompleted(int request_id,
59 int* bytes_read) {
60 if (!*bytes_read)
61 return true;
62
63 // We have more data to read.
64 DCHECK(read_buffer_);
65 content_length_ += *bytes_read;
66
67 // Release the ownership of the buffer, and store a reference
68 // to it. A new one will be allocated in OnWillRead().
69 net::IOBuffer* buffer = NULL;
70 read_buffer_.swap(&buffer);
71 // TODO(gauravsh): Should this be handled by a separate thread?
72 buffer_->contents.push_back(std::make_pair(buffer, *bytes_read));
73
74 return true;
75 }
76
77 bool X509UserCertResourceHandler::OnResponseCompleted(
78 int request_id,
79 const URLRequestStatus& urs,
80 const std::string& sec_info) {
81 // TODO(gauravsh): Verify that 'request_id' was actually a keygen form post
82 // and only then import the certificate.
83 scoped_ptr<net::CertDatabase> cert_db(new net::CertDatabase());
84 AssembleResource();
85
86 return cert_db->AddUserCert(resource_buffer_->data(), content_length_);
87 }
88
89 void X509UserCertResourceHandler::AssembleResource() {
90 size_t bytes_copied = 0;
91 resource_buffer_ = new net::IOBuffer(content_length_);
92
93 for (size_t i = 0; i < buffer_->contents.size(); ++i) {
94 net::IOBuffer* data = buffer_->contents[i].first;
95 const int data_len = buffer_->contents[i].second;
96 DCHECK(bytes_copied + data_len <= content_length_);
97 memcpy(resource_buffer_->data() + bytes_copied, data->data(), data_len);
98 bytes_copied += data_len;
99 }
100 }
OLDNEW
« no previous file with comments | « chrome/browser/renderer_host/x509_user_cert_resource_handler.h ('k') | chrome/chrome.gyp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698