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

Side by Side Diff: chrome/browser/extensions/api/messaging/message_property_provider.cc

Issue 356713005: Rename ServerBoundCert => ChannelID to reflect the current name (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fix cookies_list.js Created 6 years, 4 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
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/extensions/api/messaging/message_property_provider.h" 5 #include "chrome/browser/extensions/api/messaging/message_property_provider.h"
6 6
7 #include "base/json/json_writer.h" 7 #include "base/json/json_writer.h"
8 #include "base/logging.h" 8 #include "base/logging.h"
9 #include "base/message_loop/message_loop_proxy.h" 9 #include "base/message_loop/message_loop_proxy.h"
10 #include "base/strings/string_piece.h" 10 #include "base/strings/string_piece.h"
11 #include "base/values.h" 11 #include "base/values.h"
12 #include "chrome/browser/profiles/profile.h" 12 #include "chrome/browser/profiles/profile.h"
13 #include "content/public/browser/browser_thread.h" 13 #include "content/public/browser/browser_thread.h"
14 #include "extensions/common/api/runtime.h" 14 #include "extensions/common/api/runtime.h"
15 #include "net/base/completion_callback.h" 15 #include "net/base/completion_callback.h"
16 #include "net/cert/asn1_util.h" 16 #include "net/cert/asn1_util.h"
17 #include "net/cert/jwk_serializer.h" 17 #include "net/cert/jwk_serializer.h"
18 #include "net/ssl/server_bound_cert_service.h" 18 #include "net/ssl/channel_id_service.h"
19 #include "net/url_request/url_request_context.h" 19 #include "net/url_request/url_request_context.h"
20 #include "net/url_request/url_request_context_getter.h" 20 #include "net/url_request/url_request_context_getter.h"
21 #include "url/gurl.h" 21 #include "url/gurl.h"
22 22
23 namespace extensions { 23 namespace extensions {
24 24
25 MessagePropertyProvider::MessagePropertyProvider() {} 25 MessagePropertyProvider::MessagePropertyProvider() {}
26 26
27 void MessagePropertyProvider::GetDomainBoundCert(Profile* profile, 27 void MessagePropertyProvider::GetChannelID(Profile* profile,
28 const GURL& source_url, const DomainBoundCertCallback& reply) { 28 const GURL& source_url, const ChannelIDCallback& reply) {
29 if (!source_url.is_valid()) { 29 if (!source_url.is_valid()) {
30 // This isn't a real URL, so there's no sense in looking for a channel ID 30 // This isn't a real URL, so there's no sense in looking for a channel ID
31 // for it. Dispatch with an empty tls channel ID. 31 // for it. Dispatch with an empty tls channel ID.
32 reply.Run(std::string()); 32 reply.Run(std::string());
33 return; 33 return;
34 } 34 }
35 scoped_refptr<net::URLRequestContextGetter> request_context_getter( 35 scoped_refptr<net::URLRequestContextGetter> request_context_getter(
36 profile->GetRequestContext()); 36 profile->GetRequestContext());
37 content::BrowserThread::PostTask(content::BrowserThread::IO, FROM_HERE, 37 content::BrowserThread::PostTask(content::BrowserThread::IO, FROM_HERE,
38 base::Bind(&MessagePropertyProvider::GetDomainBoundCertOnIOThread, 38 base::Bind(&MessagePropertyProvider::GetChannelIDOnIOThread,
39 base::MessageLoopProxy::current(), 39 base::MessageLoopProxy::current(),
40 request_context_getter, 40 request_context_getter,
41 source_url.host(), 41 source_url.host(),
42 reply)); 42 reply));
43 } 43 }
44 44
45 // Helper struct to bind the memory addresses that will be written to by 45 // Helper struct to bind the memory addresses that will be written to by
46 // ServerBoundCertService::GetDomainBoundCert to the callback provided to 46 // ChannelIDService::GetChannelID to the callback provided to
47 // MessagePropertyProvider::GetDomainBoundCert. 47 // MessagePropertyProvider::GetChannelID.
48 struct MessagePropertyProvider::GetDomainBoundCertOutput { 48 struct MessagePropertyProvider::GetChannelIDOutput {
49 std::string domain_bound_private_key; 49 std::string domain_bound_private_key;
50 std::string domain_bound_cert; 50 std::string domain_bound_cert;
51 net::ServerBoundCertService::RequestHandle request_handle; 51 net::ChannelIDService::RequestHandle request_handle;
52 }; 52 };
53 53
54 // static 54 // static
55 void MessagePropertyProvider::GetDomainBoundCertOnIOThread( 55 void MessagePropertyProvider::GetChannelIDOnIOThread(
56 scoped_refptr<base::TaskRunner> original_task_runner, 56 scoped_refptr<base::TaskRunner> original_task_runner,
57 scoped_refptr<net::URLRequestContextGetter> request_context_getter, 57 scoped_refptr<net::URLRequestContextGetter> request_context_getter,
58 const std::string& host, 58 const std::string& host,
59 const DomainBoundCertCallback& reply) { 59 const ChannelIDCallback& reply) {
60 DCHECK_CURRENTLY_ON(content::BrowserThread::IO); 60 DCHECK_CURRENTLY_ON(content::BrowserThread::IO);
61 net::ServerBoundCertService* server_bound_cert_service = 61 net::ChannelIDService* channel_id_service =
62 request_context_getter->GetURLRequestContext()-> 62 request_context_getter->GetURLRequestContext()->
63 server_bound_cert_service(); 63 channel_id_service();
64 GetDomainBoundCertOutput* output = new GetDomainBoundCertOutput(); 64 GetChannelIDOutput* output = new GetChannelIDOutput();
65 net::CompletionCallback net_completion_callback = 65 net::CompletionCallback net_completion_callback =
66 base::Bind(&MessagePropertyProvider::GotDomainBoundCert, 66 base::Bind(&MessagePropertyProvider::GotChannelID,
67 original_task_runner, 67 original_task_runner,
68 base::Owned(output), 68 base::Owned(output),
69 reply); 69 reply);
70 int status = server_bound_cert_service->GetDomainBoundCert( 70 int status = channel_id_service->GetChannelID(
71 host, 71 host,
72 &output->domain_bound_private_key, 72 &output->domain_bound_private_key,
73 &output->domain_bound_cert, 73 &output->domain_bound_cert,
74 net_completion_callback, 74 net_completion_callback,
75 &output->request_handle); 75 &output->request_handle);
76 if (status == net::ERR_IO_PENDING) 76 if (status == net::ERR_IO_PENDING)
77 return; 77 return;
78 GotDomainBoundCert(original_task_runner, output, reply, status); 78 GotChannelID(original_task_runner, output, reply, status);
79 } 79 }
80 80
81 // static 81 // static
82 void MessagePropertyProvider::GotDomainBoundCert( 82 void MessagePropertyProvider::GotChannelID(
83 scoped_refptr<base::TaskRunner> original_task_runner, 83 scoped_refptr<base::TaskRunner> original_task_runner,
84 struct GetDomainBoundCertOutput* output, 84 struct GetChannelIDOutput* output,
85 const DomainBoundCertCallback& reply, 85 const ChannelIDCallback& reply,
86 int status) { 86 int status) {
87 base::Closure no_tls_channel_id_closure = base::Bind(reply, ""); 87 base::Closure no_tls_channel_id_closure = base::Bind(reply, "");
88 if (status != net::OK) { 88 if (status != net::OK) {
89 original_task_runner->PostTask(FROM_HERE, no_tls_channel_id_closure); 89 original_task_runner->PostTask(FROM_HERE, no_tls_channel_id_closure);
90 return; 90 return;
91 } 91 }
92 base::StringPiece spki; 92 base::StringPiece spki;
93 if (!net::asn1::ExtractSPKIFromDERCert(output->domain_bound_cert, &spki)) { 93 if (!net::asn1::ExtractSPKIFromDERCert(output->domain_bound_cert, &spki)) {
94 original_task_runner->PostTask(FROM_HERE, no_tls_channel_id_closure); 94 original_task_runner->PostTask(FROM_HERE, no_tls_channel_id_closure);
95 return; 95 return;
96 } 96 }
97 base::DictionaryValue jwk_value; 97 base::DictionaryValue jwk_value;
98 if (!net::JwkSerializer::ConvertSpkiFromDerToJwk(spki, &jwk_value)) { 98 if (!net::JwkSerializer::ConvertSpkiFromDerToJwk(spki, &jwk_value)) {
99 original_task_runner->PostTask(FROM_HERE, no_tls_channel_id_closure); 99 original_task_runner->PostTask(FROM_HERE, no_tls_channel_id_closure);
100 return; 100 return;
101 } 101 }
102 std::string jwk_str; 102 std::string jwk_str;
103 base::JSONWriter::Write(&jwk_value, &jwk_str); 103 base::JSONWriter::Write(&jwk_value, &jwk_str);
104 original_task_runner->PostTask(FROM_HERE, base::Bind(reply, jwk_str)); 104 original_task_runner->PostTask(FROM_HERE, base::Bind(reply, jwk_str));
105 } 105 }
106 106
107 } // namespace extensions 107 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698