OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 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 | 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/renderer/external_extension.h" | 5 #include "chrome/renderer/external_extension.h" |
6 | 6 |
7 #include "chrome/common/render_messages.h" | 7 #include "chrome/common/render_messages.h" |
8 #include "chrome/common/search_provider.h" | 8 #include "chrome/common/search_provider.h" |
9 #include "content/public/renderer/render_view.h" | 9 #include "content/public/renderer/render_view.h" |
10 #include "third_party/WebKit/public/web/WebDocument.h" | 10 #include "third_party/WebKit/public/web/WebDocument.h" |
(...skipping 98 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
109 RenderView* render_view = GetRenderView(); | 109 RenderView* render_view = GetRenderView(); |
110 if (!render_view) | 110 if (!render_view) |
111 return; | 111 return; |
112 | 112 |
113 WebLocalFrame* webframe = WebLocalFrame::frameForCurrentContext(); | 113 WebLocalFrame* webframe = WebLocalFrame::frameForCurrentContext(); |
114 if (!webframe) | 114 if (!webframe) |
115 return; | 115 return; |
116 | 116 |
117 GURL osdd_url = GURL(webframe->document().url()).Resolve(osdd_string); | 117 GURL osdd_url = GURL(webframe->document().url()).Resolve(osdd_string); |
118 if (!osdd_url.is_empty() && osdd_url.is_valid()) { | 118 if (!osdd_url.is_empty() && osdd_url.is_valid()) { |
119 webframe->countFeatureUse(blink::WebFrame::ExternalAddSearchProvider); | |
119 render_view->Send(new ChromeViewHostMsg_PageHasOSDD( | 120 render_view->Send(new ChromeViewHostMsg_PageHasOSDD( |
120 render_view->GetRoutingID(), webframe->document().url(), osdd_url, | 121 render_view->GetRoutingID(), webframe->document().url(), osdd_url, |
121 search_provider::EXPLICIT_PROVIDER)); | 122 search_provider::EXPLICIT_PROVIDER)); |
122 } | 123 } |
123 } | 124 } |
124 | 125 |
125 // static | 126 // static |
126 void ExternalExtensionWrapper::IsSearchProviderInstalled( | 127 void ExternalExtensionWrapper::IsSearchProviderInstalled( |
127 const v8::FunctionCallbackInfo<v8::Value>& args) { | 128 const v8::FunctionCallbackInfo<v8::Value>& args) { |
128 if (!args.Length() || !args[0]->IsString()) | 129 if (!args.Length() || !args[0]->IsString()) |
129 return; | 130 return; |
130 | 131 |
131 v8::String::Utf8Value utf8name(args[0]); | 132 v8::String::Utf8Value utf8name(args[0]); |
132 if (!utf8name.length()) | 133 if (!utf8name.length()) |
133 return; | 134 return; |
134 | 135 |
135 std::string name(*utf8name); | 136 std::string name(*utf8name); |
136 RenderView* render_view = GetRenderView(); | 137 RenderView* render_view = GetRenderView(); |
137 if (!render_view) | 138 if (!render_view) |
138 return; | 139 return; |
139 | 140 |
140 WebLocalFrame* webframe = WebLocalFrame::frameForCurrentContext(); | 141 WebLocalFrame* webframe = WebLocalFrame::frameForCurrentContext(); |
141 if (!webframe) | 142 if (!webframe) |
142 return; | 143 return; |
143 | 144 |
144 search_provider::InstallState install = search_provider::DENIED; | 145 search_provider::InstallState install = search_provider::DENIED; |
145 GURL inquiry_url = GURL(webframe->document().url()).Resolve(name); | 146 GURL inquiry_url = GURL(webframe->document().url()).Resolve(name); |
146 if (!inquiry_url.is_empty()) { | 147 if (!inquiry_url.is_empty()) { |
147 render_view->Send(new ChromeViewHostMsg_GetSearchProviderInstallState( | 148 webframe->countFeatureUse( |
dcheng
2015/10/17 01:15:21
Why not just add a UMA in Chrome? It doesn't seem
Evan Stade
2015/10/18 03:26:10
Jochen and other API owners wanted to follow the s
| |
148 render_view->GetRoutingID(), | 149 blink::WebFrame::ExternalIsSearchProviderInstalled); |
149 webframe->document().url(), | 150 render_view->Send(new ChromeViewHostMsg_GetSearchProviderInstallState( |
150 inquiry_url, | 151 render_view->GetRoutingID(), webframe->document().url(), inquiry_url, |
151 &install)); | 152 &install)); |
152 } | 153 } |
153 | 154 |
154 if (install == search_provider::DENIED) { | 155 if (install == search_provider::DENIED) { |
155 // FIXME: throw access denied exception. | 156 // FIXME: throw access denied exception. |
156 v8::Isolate* isolate = args.GetIsolate(); | 157 v8::Isolate* isolate = args.GetIsolate(); |
157 isolate->ThrowException(v8::Exception::Error(v8::String::Empty(isolate))); | 158 isolate->ThrowException(v8::Exception::Error(v8::String::Empty(isolate))); |
158 return; | 159 return; |
159 } | 160 } |
160 args.GetReturnValue().Set(static_cast<int32_t>(install)); | 161 args.GetReturnValue().Set(static_cast<int32_t>(install)); |
161 } | 162 } |
162 | 163 |
163 v8::Extension* ExternalExtension::Get() { | 164 v8::Extension* ExternalExtension::Get() { |
164 return new ExternalExtensionWrapper(); | 165 return new ExternalExtensionWrapper(); |
165 } | 166 } |
166 | 167 |
167 } // namespace extensions_v8 | 168 } // namespace extensions_v8 |
OLD | NEW |