Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(5076)

Unified Diff: android_webview/browser/aw_content_browser_client.cc

Issue 24228003: Upstream ShouldOverrideUrlLoading changes (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: changed a non-related line to keep chrome bots happy Created 7 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | android_webview/browser/aw_contents_client_bridge_base.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: android_webview/browser/aw_content_browser_client.cc
diff --git a/android_webview/browser/aw_content_browser_client.cc b/android_webview/browser/aw_content_browser_client.cc
index e71fddbcee0119272ce6897892b2341bca640b3c..c590984c2156fee52d1db966ee84a7f86e934b37 100644
--- a/android_webview/browser/aw_content_browser_client.cc
+++ b/android_webview/browser/aw_content_browser_client.cc
@@ -13,10 +13,13 @@
#include "android_webview/browser/jni_dependency_factory.h"
#include "android_webview/browser/net_disk_cache_remover.h"
#include "android_webview/browser/renderer_host/aw_resource_dispatcher_host_delegate.h"
+#include "android_webview/common/render_view_messages.h"
#include "android_webview/common/url_constants.h"
#include "base/base_paths_android.h"
#include "base/path_service.h"
#include "content/public/browser/access_token_store.h"
+#include "content/public/browser/browser_message_filter.h"
+#include "content/public/browser/browser_thread.h"
#include "content/public/browser/child_process_security_policy.h"
#include "content/public/browser/render_process_host.h"
#include "content/public/browser/render_view_host.h"
@@ -30,9 +33,79 @@
#include "ui/base/resource/resource_bundle.h"
#include "webkit/common/webpreferences.h"
+using content::BrowserThread;
+
namespace android_webview {
namespace {
+// TODO(sgurun) move this to its own file.
+// This class filters out incoming aw_contents related IPC messages for the
+// renderer process on the IPC thread.
+class AwContentsMessageFilter : public content::BrowserMessageFilter {
+public:
+ explicit AwContentsMessageFilter(int process_id);
+
+ // BrowserMessageFilter methods.
+ virtual void OverrideThreadForMessage(
+ const IPC::Message& message,
+ BrowserThread::ID* thread) OVERRIDE;
+ virtual bool OnMessageReceived(
+ const IPC::Message& message,
+ bool* message_was_ok) OVERRIDE;
+
+ void OnShouldOverrideUrlLoading(int routing_id,
+ const base::string16& url,
+ bool* ignore_navigation);
+
+private:
+ virtual ~AwContentsMessageFilter();
+
+ int process_id_;
+
+ DISALLOW_COPY_AND_ASSIGN(AwContentsMessageFilter);
+};
+
+AwContentsMessageFilter::AwContentsMessageFilter(int process_id)
+ : process_id_(process_id) {
+}
+
+AwContentsMessageFilter::~AwContentsMessageFilter() {
+}
+
+void AwContentsMessageFilter::OverrideThreadForMessage(
+ const IPC::Message& message, BrowserThread::ID* thread) {
+ if (message.type() == AwViewHostMsg_ShouldOverrideUrlLoading::ID) {
+ *thread = BrowserThread::UI;
+ }
+}
+
+bool AwContentsMessageFilter::OnMessageReceived(const IPC::Message& message,
+ bool* message_was_ok) {
+ bool handled = true;
+ IPC_BEGIN_MESSAGE_MAP_EX(AwContentsMessageFilter, message, *message_was_ok)
+ IPC_MESSAGE_HANDLER(AwViewHostMsg_ShouldOverrideUrlLoading,
+ OnShouldOverrideUrlLoading)
+ IPC_MESSAGE_UNHANDLED(handled = false)
+ IPC_END_MESSAGE_MAP()
+ return handled;
+}
+
+void AwContentsMessageFilter::OnShouldOverrideUrlLoading(
+ int routing_id,
+ const base::string16& url,
+ bool* ignore_navigation) {
+ DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
+ *ignore_navigation = false;
+ AwContentsClientBridgeBase* client =
+ AwContentsClientBridgeBase::FromID(process_id_, routing_id);
+ if (client) {
+ *ignore_navigation = client->ShouldOverrideUrlLoading(url);
+ } else {
+ LOG(WARNING) << "Failed to find the associated render view host for url: "
+ << url;
+ }
+}
+
class AwAccessTokenStore : public content::AccessTokenStore {
public:
AwAccessTokenStore() { }
@@ -122,6 +195,8 @@ void AwContentBrowserClient::RenderProcessHostCreated(
host->GetID(), android_webview::kContentScheme);
content::ChildProcessSecurityPolicy::GetInstance()->GrantScheme(
host->GetID(), chrome::kFileScheme);
+
+ host->AddFilter(new AwContentsMessageFilter(host->GetID()));
}
net::URLRequestContextGetter*
@@ -272,7 +347,7 @@ void AwContentBrowserClient::SelectClientCertificate(
const net::HttpNetworkSession* network_session,
net::SSLCertRequestInfo* cert_request_info,
const base::Callback<void(net::X509Certificate*)>& callback) {
- LOG(INFO) << "Client certificate request from "
+ LOG(WARNING) << "Client certificate request from "
<< cert_request_info->host_and_port
<< " rejected. (Client certificates not supported in WebView)";
callback.Run(NULL);
« no previous file with comments | « no previous file | android_webview/browser/aw_contents_client_bridge_base.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698