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/extensions/dispatcher.h" | 5 #include "chrome/renderer/extensions/dispatcher.h" |
6 | 6 |
7 #include "base/callback.h" | 7 #include "base/callback.h" |
8 #include "base/command_line.h" | 8 #include "base/command_line.h" |
9 #include "base/debug/alias.h" | 9 #include "base/debug/alias.h" |
10 #include "base/json/json_reader.h" | 10 #include "base/json/json_reader.h" |
(...skipping 1168 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1179 } | 1179 } |
1180 | 1180 |
1181 if (context_type == Feature::BLESSED_EXTENSION_CONTEXT && | 1181 if (context_type == Feature::BLESSED_EXTENSION_CONTEXT && |
1182 is_within_platform_app && | 1182 is_within_platform_app && |
1183 GetCurrentChannel() <= chrome::VersionInfo::CHANNEL_DEV && | 1183 GetCurrentChannel() <= chrome::VersionInfo::CHANNEL_DEV && |
1184 CommandLine::ForCurrentProcess()->HasSwitch( | 1184 CommandLine::ForCurrentProcess()->HasSwitch( |
1185 ::switches::kEnableAppWindowControls)) { | 1185 ::switches::kEnableAppWindowControls)) { |
1186 module_system->Require("windowControls"); | 1186 module_system->Require("windowControls"); |
1187 } | 1187 } |
1188 | 1188 |
1189 // Currently only platform apps and whitelisted component extensions support | |
1190 // the <webview> tag, because the "denyWebView" module will affect the | |
1191 // performance of DOM modifications (http://crbug.com/196453). | |
1192 // We used to limit WebView to |BLESSED_EXTENSION_CONTEXT| within platform | 1189 // We used to limit WebView to |BLESSED_EXTENSION_CONTEXT| within platform |
1193 // apps. An ext/app runs in a blessed extension context, if it is the active | 1190 // apps. An ext/app runs in a blessed extension context, if it is the active |
1194 // extension in the current process, in other words, if it is loaded in a top | 1191 // extension in the current process, in other words, if it is loaded in a top |
1195 // frame. To support webview in a non-frame extension, we have to allow | 1192 // frame. To support webview in a non-frame extension, we have to allow |
1196 // unblessed extension context as well. | 1193 // unblessed extension context as well. |
1197 if (context_type == Feature::BLESSED_EXTENSION_CONTEXT || | 1194 // Note: setting up the WebView class here, not the chrome.webview API. |
1198 context_type == Feature::UNBLESSED_EXTENSION_CONTEXT) { | 1195 // The API will be automatically set up when first used. |
1199 // Note: setting up the WebView class here, not the chrome.webview API. | 1196 if (extension) { |
1200 // The API will be automatically set up when first used. | |
1201 if (extension->HasAPIPermission(APIPermission::kWebView)) { | 1197 if (extension->HasAPIPermission(APIPermission::kWebView)) { |
not at google - send to devlin
2014/01/28 19:08:45
If I'm reading this correctly... you can merge thi
Fady Samuel
2014/01/31 22:31:45
Done.
| |
1202 module_system->Require("webView"); | 1198 module_system->Require("webView"); |
1203 bool includeExperimental = | 1199 if (GetCurrentChannel() <= chrome::VersionInfo::CHANNEL_DEV) { |
1204 GetCurrentChannel() <= chrome::VersionInfo::CHANNEL_DEV; | 1200 module_system->Require("webViewExperimental"); |
not at google - send to devlin
2014/01/28 19:08:45
(is there any way to (eventually, not now obviousl
Fady Samuel
2014/01/31 22:31:45
I'm not aware of anyway to do that. <webview> is a
| |
1205 if (!includeExperimental) { | 1201 } else { |
1206 // TODO(asargent) We need a whitelist for webview experimental. | 1202 // TODO(asargent) We need a whitelist for webview experimental. |
1207 // crbug.com/264852 | 1203 // crbug.com/264852 |
1208 std::string id_hash = base::SHA1HashString(extension->id()); | 1204 std::string id_hash = base::SHA1HashString(extension->id()); |
1209 std::string hexencoded_id_hash = base::HexEncode(id_hash.c_str(), | 1205 std::string hexencoded_id_hash = base::HexEncode(id_hash.c_str(), |
1210 id_hash.length()); | 1206 id_hash.length()); |
not at google - send to devlin
2014/01/28 19:08:45
indentation
Fady Samuel
2014/01/31 22:31:45
Done.
| |
1211 if (hexencoded_id_hash == "8C3741E3AF0B93B6E8E0DDD499BB0B74839EA578" || | 1207 if (hexencoded_id_hash == "8C3741E3AF0B93B6E8E0DDD499BB0B74839EA578" || |
1212 hexencoded_id_hash == "E703483CEF33DEC18B4B6DD84B5C776FB9182BDB" || | 1208 hexencoded_id_hash == "E703483CEF33DEC18B4B6DD84B5C776FB9182BDB" || |
1213 hexencoded_id_hash == "1A26E32DE447A17CBE5E9750CDBA78F58539B39C" || | 1209 hexencoded_id_hash == "1A26E32DE447A17CBE5E9750CDBA78F58539B39C" || |
1214 hexencoded_id_hash == "59048028102D7B4C681DBC7BC6CD980C3DC66DA3") | 1210 hexencoded_id_hash == "59048028102D7B4C681DBC7BC6CD980C3DC66DA3") { |
1215 includeExperimental = true; | 1211 module_system->Require("webViewExperimental"); |
1212 } else { | |
1213 module_system->Require("denyWebView"); | |
not at google - send to devlin
2014/01/28 19:08:45
err I don't understand. this code is executed even
Fady Samuel
2014/01/31 22:31:45
Wow, that's a silly refactor bug :P Thanks for cat
| |
1214 } | |
1216 } | 1215 } |
1217 if (includeExperimental) | |
1218 module_system->Require("webViewExperimental"); | |
1219 } else { | |
1220 module_system->Require("denyWebView"); | |
1221 } | 1216 } |
1222 } | 1217 } |
1223 | 1218 |
1224 // Same comment as above for <adview> tag. | 1219 // Same comment as above for <adview> tag. |
1225 if (context_type == Feature::BLESSED_EXTENSION_CONTEXT && | 1220 if (context_type == Feature::BLESSED_EXTENSION_CONTEXT && |
1226 is_within_platform_app) { | 1221 is_within_platform_app) { |
1227 if (CommandLine::ForCurrentProcess()->HasSwitch( | 1222 if (CommandLine::ForCurrentProcess()->HasSwitch( |
1228 ::switches::kEnableAdview)) { | 1223 ::switches::kEnableAdview)) { |
1229 if (extension->HasAPIPermission(APIPermission::kAdView)) { | 1224 if (extension->HasAPIPermission(APIPermission::kAdView)) { |
1230 module_system->Require("adView"); | 1225 module_system->Require("adView"); |
(...skipping 435 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1666 RenderView* background_view = | 1661 RenderView* background_view = |
1667 ExtensionHelper::GetBackgroundPage(extension_id); | 1662 ExtensionHelper::GetBackgroundPage(extension_id); |
1668 if (background_view) { | 1663 if (background_view) { |
1669 background_view->Send(new ExtensionHostMsg_EventAck( | 1664 background_view->Send(new ExtensionHostMsg_EventAck( |
1670 background_view->GetRoutingID())); | 1665 background_view->GetRoutingID())); |
1671 } | 1666 } |
1672 } | 1667 } |
1673 } | 1668 } |
1674 | 1669 |
1675 } // namespace extensions | 1670 } // namespace extensions |
OLD | NEW |