diff options
Diffstat (limited to 'content/browser')
7 files changed, 99 insertions, 79 deletions
diff --git a/content/browser/browser_plugin/browser_plugin_embedder.cc b/content/browser/browser_plugin/browser_plugin_embedder.cc index 152f75e..3591dec 100644 --- a/content/browser/browser_plugin/browser_plugin_embedder.cc +++ b/content/browser/browser_plugin/browser_plugin_embedder.cc @@ -81,9 +81,11 @@ bool BrowserPluginEmbedder::DidSendScreenRectsCallback( } void BrowserPluginEmbedder::DidSendScreenRects() { - GetBrowserPluginGuestManager()->ForEachGuest(GetWebContents(), base::Bind( - &BrowserPluginEmbedder::DidSendScreenRectsCallback, - base::Unretained(this))); + BrowserPluginGuestManager::FromBrowserContext( + GetWebContents()->GetBrowserContext())->ForEachGuest( + GetWebContents(), base::Bind( + &BrowserPluginEmbedder::DidSendScreenRectsCallback, + base::Unretained(this))); } bool BrowserPluginEmbedder::UnlockMouseIfNecessaryCallback( @@ -166,19 +168,12 @@ void BrowserPluginEmbedder::OnAllocateInstanceID(int request_id) { routing_id(), request_id, instance_id)); } -void BrowserPluginEmbedder::OnAttach( +void BrowserPluginEmbedder::OnGuestCallback( int instance_id, const BrowserPluginHostMsg_Attach_Params& params, - const base::DictionaryValue& extra_params) { + const base::DictionaryValue* extra_params, + BrowserPluginGuest* guest) { BrowserPluginGuestManager* guest_manager = GetBrowserPluginGuestManager(); - if (!guest_manager->CanEmbedderAccessInstanceIDMaybeKill( - GetWebContents()->GetRenderProcessHost()->GetID(), instance_id)) - return; - - BrowserPluginGuest* guest = - guest_manager->GetGuestByInstanceID( - instance_id, GetWebContents()->GetRenderProcessHost()->GetID()); - if (guest) { // There is an implicit order expectation here: // 1. The content embedder is made aware of the attachment. @@ -188,12 +183,12 @@ void BrowserPluginEmbedder::OnAttach( GetContentClient()->browser()->GuestWebContentsAttached( guest->GetWebContents(), GetWebContents(), - extra_params); - guest->Attach(GetWebContents(), params, extra_params); + *extra_params); + guest->Attach(GetWebContents(), params, *extra_params); return; } - scoped_ptr<base::DictionaryValue> copy_extra_params(extra_params.DeepCopy()); + scoped_ptr<base::DictionaryValue> copy_extra_params(extra_params->DeepCopy()); guest = guest_manager->CreateGuest( GetWebContents()->GetSiteInstance(), instance_id, params, @@ -202,9 +197,22 @@ void BrowserPluginEmbedder::OnAttach( GetContentClient()->browser()->GuestWebContentsAttached( guest->GetWebContents(), GetWebContents(), - extra_params); + *extra_params); guest->Initialize(params, GetWebContents()); } } +void BrowserPluginEmbedder::OnAttach( + int instance_id, + const BrowserPluginHostMsg_Attach_Params& params, + const base::DictionaryValue& extra_params) { + GetBrowserPluginGuestManager()->MaybeGetGuestByInstanceIDOrKill( + instance_id, GetWebContents()->GetRenderProcessHost()->GetID(), + base::Bind(&BrowserPluginEmbedder::OnGuestCallback, + base::Unretained(this), + instance_id, + params, + &extra_params)); +} + } // namespace content diff --git a/content/browser/browser_plugin/browser_plugin_embedder.h b/content/browser/browser_plugin/browser_plugin_embedder.h index bce57a3..4df3dc4 100644 --- a/content/browser/browser_plugin/browser_plugin_embedder.h +++ b/content/browser/browser_plugin/browser_plugin_embedder.h @@ -97,6 +97,13 @@ class CONTENT_EXPORT BrowserPluginEmbedder : public WebContentsObserver { bool UnlockMouseIfNecessaryCallback(const NativeWebKeyboardEvent& event, BrowserPluginGuest* guest); + // Called by the content embedder when a guest exists with the provided + // |instance_id|. + void OnGuestCallback(int instance_id, + const BrowserPluginHostMsg_Attach_Params& params, + const base::DictionaryValue* extra_params, + BrowserPluginGuest* guest); + // Message handlers. void OnAllocateInstanceID(int request_id); diff --git a/content/browser/browser_plugin/browser_plugin_guest.cc b/content/browser/browser_plugin/browser_plugin_guest.cc index eddc925..6f6d975 100644 --- a/content/browser/browser_plugin/browser_plugin_guest.cc +++ b/content/browser/browser_plugin/browser_plugin_guest.cc @@ -98,8 +98,20 @@ class BrowserPluginGuest::NewWindowRequest : public PermissionRequest { const std::string& user_input) OVERRIDE { int embedder_render_process_id = guest_->embedder_web_contents()->GetRenderProcessHost()->GetID(); - BrowserPluginGuest* guest = guest_->GetBrowserPluginGuestManager()-> - GetGuestByInstanceID(instance_id_, embedder_render_process_id); + guest_->GetBrowserPluginGuestManager()-> + MaybeGetGuestByInstanceIDOrKill( + instance_id_, + embedder_render_process_id, + base::Bind(&BrowserPluginGuest::NewWindowRequest::RespondInternal, + base::Unretained(this), + should_allow)); + } + + private: + virtual ~NewWindowRequest() {} + + void RespondInternal(bool should_allow, + BrowserPluginGuest* guest) { if (!guest) { VLOG(0) << "Guest not found. Instance ID: " << instance_id_; return; @@ -110,8 +122,6 @@ class BrowserPluginGuest::NewWindowRequest : public PermissionRequest { guest->Destroy(); } - private: - virtual ~NewWindowRequest() {} int instance_id_; }; diff --git a/content/browser/browser_plugin/browser_plugin_guest_manager.cc b/content/browser/browser_plugin/browser_plugin_guest_manager.cc index 4bc4235..8e44c7f0 100644 --- a/content/browser/browser_plugin/browser_plugin_guest_manager.cc +++ b/content/browser/browser_plugin/browser_plugin_guest_manager.cc @@ -121,18 +121,31 @@ BrowserPluginGuest* BrowserPluginGuestManager::CreateGuest( extra_params.Pass()); } -BrowserPluginGuest* BrowserPluginGuestManager::GetGuestByInstanceID( - int instance_id, - int embedder_render_process_id) const { - if (!GetDelegate()) - return NULL; +static void BrowserPluginGuestByInstanceIDCallback( + const BrowserPluginGuestManager::GuestByInstanceIDCallback& callback, + WebContents* guest_web_contents) { + if (!guest_web_contents) { + callback.Run(NULL); + return; + } + callback.Run(static_cast<WebContentsImpl*>(guest_web_contents)-> + GetBrowserPluginGuest()); +} - WebContentsImpl* guest_web_contents = static_cast<WebContentsImpl*>( - GetDelegate()->GetGuestByInstanceID(instance_id, - embedder_render_process_id)); +void BrowserPluginGuestManager::MaybeGetGuestByInstanceIDOrKill( + int instance_id, + int embedder_render_process_id, + const GuestByInstanceIDCallback& callback) const { + if (!GetDelegate()) { + callback.Run(NULL); + return; + } - return guest_web_contents ? - guest_web_contents->GetBrowserPluginGuest() : NULL; + GetDelegate()->MaybeGetGuestByInstanceIDOrKill( + instance_id, + embedder_render_process_id, + base::Bind(&BrowserPluginGuestByInstanceIDCallback, + callback)); } void BrowserPluginGuestManager::AddGuest(int instance_id, @@ -148,14 +161,11 @@ void BrowserPluginGuestManager::RemoveGuest(int instance_id) { GetDelegate()->RemoveGuest(instance_id); } -bool BrowserPluginGuestManager::CanEmbedderAccessInstanceIDMaybeKill( - int embedder_render_process_id, - int instance_id) const { - if (!GetDelegate()) - return false; - - return GetDelegate()->CanEmbedderAccessInstanceIDMaybeKill( - embedder_render_process_id, instance_id); +static void BrowserPluginGuestMessageCallback(const IPC::Message& message, + BrowserPluginGuest* guest) { + if (!guest) + return; + guest->OnMessageReceivedFromEmbedder(message); } void BrowserPluginGuestManager::OnMessageReceived(const IPC::Message& message, @@ -166,11 +176,10 @@ void BrowserPluginGuestManager::OnMessageReceived(const IPC::Message& message, PickleIterator iter(message); bool success = iter.ReadInt(&instance_id); DCHECK(success); - BrowserPluginGuest* guest = - GetGuestByInstanceID(instance_id, render_process_id); - if (!guest) - return; - guest->OnMessageReceivedFromEmbedder(message); + MaybeGetGuestByInstanceIDOrKill(instance_id, + render_process_id, + base::Bind(&BrowserPluginGuestMessageCallback, + message)); } SiteInstance* BrowserPluginGuestManager::GetGuestSiteInstance( diff --git a/content/browser/browser_plugin/browser_plugin_guest_manager.h b/content/browser/browser_plugin/browser_plugin_guest_manager.h index 3c157fe..31210dd 100644 --- a/content/browser/browser_plugin/browser_plugin_guest_manager.h +++ b/content/browser/browser_plugin/browser_plugin_guest_manager.h @@ -71,13 +71,6 @@ class CONTENT_EXPORT BrowserPluginGuestManager : const BrowserPluginHostMsg_Attach_Params& params, scoped_ptr<base::DictionaryValue> extra_params); - // Returns a BrowserPluginGuest given an |instance_id|. Returns NULL if the - // guest wasn't found. If the embedder is not permitted to access the given - // |instance_id|, the embedder is killed, and NULL is returned. - BrowserPluginGuest* GetGuestByInstanceID( - int instance_id, - int embedder_render_process_id) const; - // Adds a new |guest_web_contents| to the embedder (overridable in test). virtual void AddGuest(int instance_id, WebContents* guest_web_contents); @@ -85,10 +78,11 @@ class CONTENT_EXPORT BrowserPluginGuestManager : // BrowserPluginGuestManager. void RemoveGuest(int instance_id); - // Returns whether the specified embedder is permitted to access the given - // |instance_id|, and kills the embedder if not. - bool CanEmbedderAccessInstanceIDMaybeKill(int embedder_render_process_id, - int instance_id) const; + typedef base::Callback<void(BrowserPluginGuest*)> GuestByInstanceIDCallback; + void MaybeGetGuestByInstanceIDOrKill( + int instance_id, + int embedder_render_process_id, + const GuestByInstanceIDCallback& callback) const; typedef base::Callback<bool(BrowserPluginGuest*)> GuestCallback; bool ForEachGuest(WebContents* embedder_web_contents, @@ -111,6 +105,11 @@ class CONTENT_EXPORT BrowserPluginGuestManager : // The BrowserContext in which this manager this stored. BrowserContext* context_; + // Contains guests' WebContents, mapping from their instance ids. + typedef std::map<int, WebContents*> GuestInstanceMap; + GuestInstanceMap guest_web_contents_by_instance_id_; + int next_instance_id_; + DISALLOW_COPY_AND_ASSIGN(BrowserPluginGuestManager); }; diff --git a/content/browser/browser_plugin/test_guest_manager_delegate.cc b/content/browser/browser_plugin/test_guest_manager_delegate.cc index 544e4dc..11d3b34 100644 --- a/content/browser/browser_plugin/test_guest_manager_delegate.cc +++ b/content/browser/browser_plugin/test_guest_manager_delegate.cc @@ -43,26 +43,17 @@ void TestGuestManagerDelegate::RemoveGuest( guest_web_contents_by_instance_id_.erase(it); } -WebContents* TestGuestManagerDelegate::GetGuestByInstanceID( - int guest_instance_id, - int embedder_render_process_id) { +void TestGuestManagerDelegate::MaybeGetGuestByInstanceIDOrKill( + int guest_instance_id, + int embedder_render_process_id, + const GuestByInstanceIDCallback& callback) { GuestInstanceMap::const_iterator it = guest_web_contents_by_instance_id_.find(guest_instance_id); - if (it == guest_web_contents_by_instance_id_.end()) - return NULL; - return it->second; -} - -bool TestGuestManagerDelegate::CanEmbedderAccessInstanceIDMaybeKill( - int embedder_render_process_id, - int guest_instance_id) { - return true; -} - -bool TestGuestManagerDelegate::CanEmbedderAccessInstanceID( - int embedder_render_process_id, - int guest_instance_id) { - return true; + if (it == guest_web_contents_by_instance_id_.end()) { + callback.Run(NULL); + return; + } + callback.Run(it->second); } SiteInstance* TestGuestManagerDelegate::GetGuestSiteInstance( diff --git a/content/browser/browser_plugin/test_guest_manager_delegate.h b/content/browser/browser_plugin/test_guest_manager_delegate.h index ebd1656..63f2811 100644 --- a/content/browser/browser_plugin/test_guest_manager_delegate.h +++ b/content/browser/browser_plugin/test_guest_manager_delegate.h @@ -25,14 +25,10 @@ class TestGuestManagerDelegate : public BrowserPluginGuestManagerDelegate { virtual void AddGuest(int guest_instance_id, WebContents* guest_web_contents) OVERRIDE; virtual void RemoveGuest(int guest_instance_id) OVERRIDE; - virtual WebContents* GetGuestByInstanceID( + virtual void MaybeGetGuestByInstanceIDOrKill( int guest_instance_id, - int embedder_render_process_id) OVERRIDE; - virtual bool CanEmbedderAccessInstanceIDMaybeKill( int embedder_render_process_id, - int guest_instance_id) OVERRIDE; - virtual bool CanEmbedderAccessInstanceID(int embedder_render_process_id, - int guest_instance_id) OVERRIDE; + const GuestByInstanceIDCallback& callback) OVERRIDE; virtual SiteInstance* GetGuestSiteInstance( const GURL& guest_site) OVERRIDE; virtual bool ForEachGuest(WebContents* embedder_web_contents, |