Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/guest_view/guest_view_base.h" | 5 #include "chrome/browser/guest_view/guest_view_base.h" |
| 6 | 6 |
| 7 #include "base/lazy_instance.h" | 7 #include "base/lazy_instance.h" |
| 8 #include "base/strings/utf_string_conversions.h" | 8 #include "base/strings/utf_string_conversions.h" |
| 9 #include "chrome/browser/guest_view/app_view/app_view_guest.h" | 9 #include "chrome/browser/guest_view/app_view/app_view_guest.h" |
| 10 #include "chrome/browser/guest_view/extension_options/extension_options_guest.h" | 10 #include "chrome/browser/guest_view/extension_options/extension_options_guest.h" |
| 11 #include "chrome/browser/guest_view/guest_view_constants.h" | 11 #include "chrome/browser/guest_view/guest_view_constants.h" |
| 12 #include "chrome/browser/guest_view/guest_view_manager.h" | 12 #include "chrome/browser/guest_view/guest_view_manager.h" |
| 13 #include "chrome/browser/guest_view/web_view/web_view_guest.h" | 13 #include "chrome/browser/guest_view/web_view/web_view_guest.h" |
| 14 #include "chrome/common/content_settings.h" | 14 #include "chrome/common/content_settings.h" |
| 15 #include "content/public/browser/render_frame_host.h" | 15 #include "content/public/browser/render_frame_host.h" |
| 16 #include "content/public/browser/render_process_host.h" | 16 #include "content/public/browser/render_process_host.h" |
| 17 #include "content/public/browser/render_view_host.h" | 17 #include "content/public/browser/render_view_host.h" |
| 18 #include "content/public/browser/web_contents.h" | 18 #include "content/public/browser/web_contents.h" |
| 19 #include "content/public/common/url_constants.h" | 19 #include "content/public/common/url_constants.h" |
| 20 #include "extensions/browser/event_router.h" | 20 #include "extensions/browser/event_router.h" |
| 21 #include "extensions/browser/extension_registry.h" | |
| 22 #include "extensions/browser/process_map.h" | |
| 23 #include "extensions/common/features/feature.h" | |
| 24 #include "extensions/common/features/feature_provider.h" | |
| 21 #include "third_party/WebKit/public/web/WebInputEvent.h" | 25 #include "third_party/WebKit/public/web/WebInputEvent.h" |
| 22 | 26 |
| 23 using content::WebContents; | 27 using content::WebContents; |
| 24 | 28 |
| 25 namespace { | 29 namespace { |
| 26 | 30 |
| 27 typedef std::map<std::string, GuestViewBase::GuestCreationCallback> | 31 typedef std::map<std::string, GuestViewBase::GuestCreationCallback> |
| 28 GuestViewCreationMap; | 32 GuestViewCreationMap; |
| 29 static base::LazyInstance<GuestViewCreationMap> guest_view_registry = | 33 static base::LazyInstance<GuestViewCreationMap> guest_view_registry = |
| 30 LAZY_INSTANCE_INITIALIZER; | 34 LAZY_INSTANCE_INITIALIZER; |
| (...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 90 : embedder_web_contents_(NULL), | 94 : embedder_web_contents_(NULL), |
| 91 embedder_render_process_id_(0), | 95 embedder_render_process_id_(0), |
| 92 browser_context_(browser_context), | 96 browser_context_(browser_context), |
| 93 guest_instance_id_(guest_instance_id), | 97 guest_instance_id_(guest_instance_id), |
| 94 view_instance_id_(guestview::kInstanceIDNone), | 98 view_instance_id_(guestview::kInstanceIDNone), |
| 95 initialized_(false), | 99 initialized_(false), |
| 96 auto_size_enabled_(false), | 100 auto_size_enabled_(false), |
| 97 weak_ptr_factory_(this) { | 101 weak_ptr_factory_(this) { |
| 98 } | 102 } |
| 99 | 103 |
| 100 void GuestViewBase::Init( | 104 void GuestViewBase::Init(const std::string& embedder_extension_id, |
| 101 const std::string& embedder_extension_id, | 105 content::WebContents* embedder_web_contents, |
| 102 int embedder_render_process_id, | 106 const base::DictionaryValue& create_params, |
| 103 const base::DictionaryValue& create_params, | 107 const WebContentsCreatedCallback& callback) { |
| 104 const WebContentsCreatedCallback& callback) { | |
| 105 if (initialized_) | 108 if (initialized_) |
| 106 return; | 109 return; |
| 107 initialized_ = true; | 110 initialized_ = true; |
| 108 | 111 |
| 109 if (!CanEmbedderUseGuestView(embedder_extension_id)) { | 112 extensions::Feature* feature = |
| 113 extensions::FeatureProvider::GetAPIFeatures()->GetFeature( | |
| 114 GetApiNamespace()); | |
| 115 CHECK(feature); | |
|
Fady Samuel
2014/08/07 23:01:18
Do we really want to kill the browser in this case
not at google - send to devlin
2014/08/07 23:02:55
yes, because it can't possibly happen unless someb
| |
| 116 | |
| 117 extensions::ProcessMap* process_map = | |
| 118 extensions::ProcessMap::Get(browser_context()); | |
| 119 CHECK(process_map); | |
| 120 | |
| 121 const extensions::Extension* embedder_extension = | |
| 122 extensions::ExtensionRegistry::Get(browser_context_) | |
| 123 ->enabled_extensions() | |
| 124 .GetByID(embedder_extension_id); | |
| 125 int embedder_process_id = | |
| 126 embedder_web_contents->GetRenderProcessHost()->GetID(); | |
| 127 | |
| 128 extensions::Feature::Availability availability = | |
| 129 feature->IsAvailableToContext( | |
| 130 embedder_extension, | |
| 131 process_map->GuessContextType(embedder_extension, | |
| 132 embedder_process_id), | |
| 133 embedder_web_contents->GetLastCommittedURL()); | |
| 134 if (!availability.is_available()) { | |
| 110 callback.Run(NULL); | 135 callback.Run(NULL); |
| 111 return; | 136 return; |
| 112 } | 137 } |
| 113 | 138 |
| 114 CreateWebContents(embedder_extension_id, | 139 CreateWebContents(embedder_extension_id, |
| 115 embedder_render_process_id, | 140 embedder_process_id, |
| 116 create_params, | 141 create_params, |
| 117 base::Bind(&GuestViewBase::CompleteInit, | 142 base::Bind(&GuestViewBase::CompleteInit, |
| 118 AsWeakPtr(), | 143 AsWeakPtr(), |
| 119 embedder_extension_id, | 144 embedder_extension_id, |
| 120 embedder_render_process_id, | 145 embedder_process_id, |
| 121 callback)); | 146 callback)); |
| 122 } | 147 } |
| 123 | 148 |
| 124 void GuestViewBase::InitWithWebContents( | 149 void GuestViewBase::InitWithWebContents( |
| 125 const std::string& embedder_extension_id, | 150 const std::string& embedder_extension_id, |
| 126 int embedder_render_process_id, | 151 int embedder_render_process_id, |
| 127 content::WebContents* guest_web_contents) { | 152 content::WebContents* guest_web_contents) { |
| 128 DCHECK(guest_web_contents); | 153 DCHECK(guest_web_contents); |
| 129 content::RenderProcessHost* embedder_render_process_host = | 154 content::RenderProcessHost* embedder_render_process_host = |
| 130 content::RenderProcessHost::FromID(embedder_render_process_id); | 155 content::RenderProcessHost::FromID(embedder_render_process_id); |
| (...skipping 309 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 440 guest_web_contents); | 465 guest_web_contents); |
| 441 callback.Run(guest_web_contents); | 466 callback.Run(guest_web_contents); |
| 442 } | 467 } |
| 443 | 468 |
| 444 // static | 469 // static |
| 445 void GuestViewBase::RegisterGuestViewTypes() { | 470 void GuestViewBase::RegisterGuestViewTypes() { |
| 446 AppViewGuest::Register(); | 471 AppViewGuest::Register(); |
| 447 ExtensionOptionsGuest::Register(); | 472 ExtensionOptionsGuest::Register(); |
| 448 WebViewGuest::Register(); | 473 WebViewGuest::Register(); |
| 449 } | 474 } |
| OLD | NEW |