Chromium Code Reviews| Index: extensions/renderer/dispatcher.cc |
| diff --git a/extensions/renderer/dispatcher.cc b/extensions/renderer/dispatcher.cc |
| index c22774aaed8605b259b6b123cc0ed8c666dc75ff..2667ebd0b7205e47231a4c3eb43ba502bf2b6baf 100644 |
| --- a/extensions/renderer/dispatcher.cc |
| +++ b/extensions/renderer/dispatcher.cc |
| @@ -14,6 +14,7 @@ |
| #include "base/strings/string_piece.h" |
| #include "base/strings/string_split.h" |
| #include "base/strings/string_util.h" |
| +#include "base/strings/utf_string_conversions.h" |
| #include "base/time/time.h" |
| #include "base/values.h" |
| #include "content/grit/content_resources.h" |
| @@ -28,6 +29,7 @@ |
| #include "extensions/common/extension_messages.h" |
| #include "extensions/common/extension_urls.h" |
| #include "extensions/common/feature_switch.h" |
| +#include "extensions/common/features/behavior_feature.h" |
| #include "extensions/common/features/feature.h" |
| #include "extensions/common/features/feature_provider.h" |
| #include "extensions/common/manifest.h" |
| @@ -98,6 +100,7 @@ |
| #include "ui/base/resource/resource_bundle.h" |
| #include "v8/include/v8.h" |
| +using base::ASCIIToUTF16; |
|
Devlin
2015/07/10 21:51:23
avoid using "usings" when it's less than about 5 -
|
| using base::UserMetricsAction; |
| using blink::WebDataSource; |
| using blink::WebDocument; |
| @@ -912,6 +915,7 @@ void Dispatcher::OnMessageInvoke(const std::string& extension_id, |
| void Dispatcher::OnSetChannel(int channel) { |
| delegate_->SetChannel(channel); |
| + AddChannelSpecificFeatures(); |
| } |
| void Dispatcher::OnSetFunctionNames(const std::vector<std::string>& names) { |
| @@ -1448,4 +1452,20 @@ void Dispatcher::RequireGuestViewModules(ScriptContext* context) { |
| } |
| } |
| +void Dispatcher::AddChannelSpecificFeatures() { |
| + WebString extension_scheme(ASCIIToUTF16(extensions::kExtensionScheme)); |
|
Devlin
2015/07/10 21:51:23
This would be simpler using WebString::fromUtf8(kE
|
| + |
| + // chrome-extension: resources should be allowed to register a Service Worker. |
| + if (IsExtensionAllowedToUseServiceWorker()) |
| + WebSecurityPolicy::registerURLSchemeAsAllowingServiceWorkers( |
| + extension_scheme); |
| +} |
| + |
| +bool Dispatcher::IsExtensionAllowedToUseServiceWorker() { |
|
Devlin
2015/07/10 21:51:23
It's fine to inline this function in AddChannelSpe
|
| + return FeatureProvider::GetBehaviorFeature( |
| + BehaviorFeature::kServiceWorker) |
| + ->IsAvailableToEnvironment() |
| + .is_available(); |
| +} |
| + |
| } // namespace extensions |