Enable node integration for pages in devtools extension
This commit is contained in:
parent
7e1f159185
commit
134f9019eb
2 changed files with 29 additions and 16 deletions
|
@ -34,6 +34,7 @@
|
||||||
#include "native_mate/dictionary.h"
|
#include "native_mate/dictionary.h"
|
||||||
#include "net/base/net_errors.h"
|
#include "net/base/net_errors.h"
|
||||||
#include "third_party/WebKit/public/web/WebCustomElement.h"
|
#include "third_party/WebKit/public/web/WebCustomElement.h"
|
||||||
|
#include "third_party/WebKit/public/web/WebDocument.h"
|
||||||
#include "third_party/WebKit/public/web/WebFrameWidget.h"
|
#include "third_party/WebKit/public/web/WebFrameWidget.h"
|
||||||
#include "third_party/WebKit/public/web/WebLocalFrame.h"
|
#include "third_party/WebKit/public/web/WebLocalFrame.h"
|
||||||
#include "third_party/WebKit/public/web/WebPluginParams.h"
|
#include "third_party/WebKit/public/web/WebPluginParams.h"
|
||||||
|
@ -62,6 +63,7 @@ class AtomRenderFrameObserver : public content::RenderFrameObserver {
|
||||||
AtomRenderFrameObserver(content::RenderFrame* frame,
|
AtomRenderFrameObserver(content::RenderFrame* frame,
|
||||||
AtomRendererClient* renderer_client)
|
AtomRendererClient* renderer_client)
|
||||||
: content::RenderFrameObserver(frame),
|
: content::RenderFrameObserver(frame),
|
||||||
|
render_frame_(frame),
|
||||||
world_id_(-1),
|
world_id_(-1),
|
||||||
renderer_client_(renderer_client) {}
|
renderer_client_(renderer_client) {}
|
||||||
|
|
||||||
|
@ -72,16 +74,17 @@ class AtomRenderFrameObserver : public content::RenderFrameObserver {
|
||||||
if (world_id_ != -1 && world_id_ != world_id)
|
if (world_id_ != -1 && world_id_ != world_id)
|
||||||
return;
|
return;
|
||||||
world_id_ = world_id;
|
world_id_ = world_id;
|
||||||
renderer_client_->DidCreateScriptContext(context);
|
renderer_client_->DidCreateScriptContext(context, render_frame_);
|
||||||
}
|
}
|
||||||
void WillReleaseScriptContext(v8::Local<v8::Context> context,
|
void WillReleaseScriptContext(v8::Local<v8::Context> context,
|
||||||
int world_id) override {
|
int world_id) override {
|
||||||
if (world_id_ != world_id)
|
if (world_id_ != world_id)
|
||||||
return;
|
return;
|
||||||
renderer_client_->WillReleaseScriptContext(context);
|
renderer_client_->WillReleaseScriptContext(context, render_frame_);
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
content::RenderFrame* render_frame_;
|
||||||
int world_id_;
|
int world_id_;
|
||||||
AtomRendererClient* renderer_client_;
|
AtomRendererClient* renderer_client_;
|
||||||
|
|
||||||
|
@ -105,6 +108,11 @@ void AddRenderBindings(v8::Isolate* isolate,
|
||||||
base::Bind(GetRenderProcessPreferences, preferences_manager));
|
base::Bind(GetRenderProcessPreferences, preferences_manager));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool IsDevToolsExtension(content::RenderFrame* render_frame) {
|
||||||
|
return static_cast<GURL>(render_frame->GetWebFrame()->document().url())
|
||||||
|
.SchemeIs("chrome-extension");
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
AtomRendererClient::AtomRendererClient()
|
AtomRendererClient::AtomRendererClient()
|
||||||
|
@ -150,15 +158,11 @@ void AtomRendererClient::RenderThreadStarted() {
|
||||||
void AtomRendererClient::RenderFrameCreated(
|
void AtomRendererClient::RenderFrameCreated(
|
||||||
content::RenderFrame* render_frame) {
|
content::RenderFrame* render_frame) {
|
||||||
new PepperHelper(render_frame);
|
new PepperHelper(render_frame);
|
||||||
|
new AtomRenderFrameObserver(render_frame, this);
|
||||||
|
|
||||||
// Allow file scheme to handle service worker by default.
|
// Allow file scheme to handle service worker by default.
|
||||||
|
// FIXME(zcbenz): Can this be moved elsewhere?
|
||||||
blink::WebSecurityPolicy::registerURLSchemeAsAllowingServiceWorkers("file");
|
blink::WebSecurityPolicy::registerURLSchemeAsAllowingServiceWorkers("file");
|
||||||
|
|
||||||
// Only insert node integration for the main frame.
|
|
||||||
if (!render_frame->IsMainFrame())
|
|
||||||
return;
|
|
||||||
|
|
||||||
new AtomRenderFrameObserver(render_frame, this);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AtomRendererClient::RenderViewCreated(content::RenderView* render_view) {
|
void AtomRendererClient::RenderViewCreated(content::RenderView* render_view) {
|
||||||
|
@ -187,7 +191,7 @@ void AtomRendererClient::RunScriptsAtDocumentStart(
|
||||||
render_frame->GetWebFrame()->executeScript(
|
render_frame->GetWebFrame()->executeScript(
|
||||||
blink::WebScriptSource("void 0"));
|
blink::WebScriptSource("void 0"));
|
||||||
|
|
||||||
// Inform the docuemnt start pharse.
|
// Inform the document start pharse.
|
||||||
node::Environment* env = node_bindings_->uv_env();
|
node::Environment* env = node_bindings_->uv_env();
|
||||||
if (env) {
|
if (env) {
|
||||||
v8::HandleScope handle_scope(env->isolate());
|
v8::HandleScope handle_scope(env->isolate());
|
||||||
|
@ -197,7 +201,7 @@ void AtomRendererClient::RunScriptsAtDocumentStart(
|
||||||
|
|
||||||
void AtomRendererClient::RunScriptsAtDocumentEnd(
|
void AtomRendererClient::RunScriptsAtDocumentEnd(
|
||||||
content::RenderFrame* render_frame) {
|
content::RenderFrame* render_frame) {
|
||||||
// Inform the docuemnt end pharse.
|
// Inform the document end pharse.
|
||||||
node::Environment* env = node_bindings_->uv_env();
|
node::Environment* env = node_bindings_->uv_env();
|
||||||
if (env) {
|
if (env) {
|
||||||
v8::HandleScope handle_scope(env->isolate());
|
v8::HandleScope handle_scope(env->isolate());
|
||||||
|
@ -225,7 +229,12 @@ bool AtomRendererClient::OverrideCreatePlugin(
|
||||||
}
|
}
|
||||||
|
|
||||||
void AtomRendererClient::DidCreateScriptContext(
|
void AtomRendererClient::DidCreateScriptContext(
|
||||||
v8::Handle<v8::Context> context) {
|
v8::Handle<v8::Context> context, content::RenderFrame* render_frame) {
|
||||||
|
// Only allow node integration for the main frame, unless it is a devtools
|
||||||
|
// extension page.
|
||||||
|
if (!render_frame->IsMainFrame() && !IsDevToolsExtension(render_frame))
|
||||||
|
return;
|
||||||
|
|
||||||
// Whether the node binding has been initialized.
|
// Whether the node binding has been initialized.
|
||||||
bool first_time = node_bindings_->uv_env() == nullptr;
|
bool first_time = node_bindings_->uv_env() == nullptr;
|
||||||
|
|
||||||
|
@ -256,9 +265,11 @@ void AtomRendererClient::DidCreateScriptContext(
|
||||||
}
|
}
|
||||||
|
|
||||||
void AtomRendererClient::WillReleaseScriptContext(
|
void AtomRendererClient::WillReleaseScriptContext(
|
||||||
v8::Handle<v8::Context> context) {
|
v8::Handle<v8::Context> context, content::RenderFrame* render_frame) {
|
||||||
|
if (render_frame->IsMainFrame()) {
|
||||||
node::Environment* env = node::Environment::GetCurrent(context);
|
node::Environment* env = node::Environment::GetCurrent(context);
|
||||||
mate::EmitEvent(env->isolate(), env->process_object(), "exit");
|
mate::EmitEvent(env->isolate(), env->process_object(), "exit");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool AtomRendererClient::ShouldFork(blink::WebLocalFrame* frame,
|
bool AtomRendererClient::ShouldFork(blink::WebLocalFrame* frame,
|
||||||
|
|
|
@ -21,8 +21,10 @@ class AtomRendererClient : public content::ContentRendererClient {
|
||||||
AtomRendererClient();
|
AtomRendererClient();
|
||||||
virtual ~AtomRendererClient();
|
virtual ~AtomRendererClient();
|
||||||
|
|
||||||
void DidCreateScriptContext(v8::Handle<v8::Context> context);
|
void DidCreateScriptContext(
|
||||||
void WillReleaseScriptContext(v8::Handle<v8::Context> context);
|
v8::Handle<v8::Context> context, content::RenderFrame* render_frame);
|
||||||
|
void WillReleaseScriptContext(
|
||||||
|
v8::Handle<v8::Context> context, content::RenderFrame* render_frame);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
enum NodeIntegration {
|
enum NodeIntegration {
|
||||||
|
|
Loading…
Reference in a new issue