Skip to content

Commit

Permalink
fix: webFrame spell checker APIs crashing in sandboxed renderers (#29053
Browse files Browse the repository at this point in the history
)
  • Loading branch information
miniak committed May 10, 2021
1 parent 1336978 commit aea8d53
Show file tree
Hide file tree
Showing 7 changed files with 177 additions and 166 deletions.
4 changes: 2 additions & 2 deletions shell/renderer/api/electron_api_web_frame.cc
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@
#include "shell/renderer/api/context_bridge/object_cache.h"
#include "shell/renderer/api/electron_api_context_bridge.h"
#include "shell/renderer/api/electron_api_spell_check_client.h"
#include "shell/renderer/electron_renderer_client.h"
#include "shell/renderer/renderer_client_base.h"
#include "third_party/blink/public/common/browser_interface_broker_proxy.h"
#include "third_party/blink/public/common/page/page_zoom.h"
#include "third_party/blink/public/common/web_cache/web_cache_resource_type_stats.h"
Expand Down Expand Up @@ -121,7 +121,7 @@ bool SpellCheckWord(content::RenderFrame* render_frame,
size_t start;
size_t length;

ElectronRendererClient* client = ElectronRendererClient::Get();
RendererClientBase* client = RendererClientBase::Get();

std::u16string w = base::UTF8ToUTF16(word);
int id = render_frame->GetRoutingID();
Expand Down
14 changes: 1 addition & 13 deletions shell/renderer/electron_renderer_client.cc
Original file line number Diff line number Diff line change
Expand Up @@ -35,27 +35,15 @@ bool IsDevToolsExtension(content::RenderFrame* render_frame) {

} // namespace

// static
ElectronRendererClient* ElectronRendererClient::self_ = nullptr;

ElectronRendererClient::ElectronRendererClient()
: node_bindings_(
NodeBindings::Create(NodeBindings::BrowserEnvironment::kRenderer)),
electron_bindings_(new ElectronBindings(node_bindings_->uv_loop())) {
DCHECK(!self_) << "Cannot have two ElectronRendererClient";
self_ = this;
}
electron_bindings_(new ElectronBindings(node_bindings_->uv_loop())) {}

ElectronRendererClient::~ElectronRendererClient() {
asar::ClearArchives();
}

// static
ElectronRendererClient* ElectronRendererClient::Get() {
DCHECK(self_);
return self_;
}

void ElectronRendererClient::RenderFrameCreated(
content::RenderFrame* render_frame) {
new ElectronRenderFrameObserver(render_frame, this);
Expand Down
4 changes: 0 additions & 4 deletions shell/renderer/electron_renderer_client.h
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,6 @@ class ElectronRendererClient : public RendererClientBase {
ElectronRendererClient();
~ElectronRendererClient() override;

static ElectronRendererClient* Get();

// electron::RendererClientBase:
void DidCreateScriptContext(v8::Handle<v8::Context> context,
content::RenderFrame* render_frame) override;
Expand Down Expand Up @@ -68,8 +66,6 @@ class ElectronRendererClient : public RendererClientBase {
// assertion, so we have to keep a book of injected web frames.
std::set<content::RenderFrame*> injected_frames_;

static ElectronRendererClient* self_;

DISALLOW_COPY_AND_ASSIGN(ElectronRendererClient);
};

Expand Down
15 changes: 14 additions & 1 deletion shell/renderer/renderer_client_base.cc
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,9 @@ std::vector<std::string> ParseSchemesCLISwitch(base::CommandLine* command_line,
base::SPLIT_WANT_NONEMPTY);
}

// static
RendererClientBase* g_renderer_client_base = nullptr;

} // namespace

RendererClientBase::RendererClientBase() {
Expand Down Expand Up @@ -123,9 +126,13 @@ RendererClientBase::RendererClientBase() {
DCHECK(command_line->HasSwitch(::switches::kRendererClientId));
renderer_client_id_ =
command_line->GetSwitchValueASCII(::switches::kRendererClientId);

g_renderer_client_base = this;
}

RendererClientBase::~RendererClientBase() = default;
RendererClientBase::~RendererClientBase() {
g_renderer_client_base = nullptr;
}

void RendererClientBase::DidCreateScriptContext(
v8::Handle<v8::Context> context,
Expand All @@ -137,6 +144,12 @@ void RendererClientBase::DidCreateScriptContext(
global.SetHidden("contextId", context_id);
}

// static
RendererClientBase* RendererClientBase::Get() {
DCHECK(g_renderer_client_base);
return g_renderer_client_base;
}

void RendererClientBase::BindProcess(v8::Isolate* isolate,
gin_helper::Dictionary* process,
content::RenderFrame* render_frame) {
Expand Down
2 changes: 2 additions & 0 deletions shell/renderer/renderer_client_base.h
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,8 @@ class RendererClientBase : public content::ContentRendererClient
RendererClientBase();
~RendererClientBase() override;

static RendererClientBase* Get();

#if BUILDFLAG(ENABLE_BUILTIN_SPELLCHECKER)
// service_manager::LocalInterfaceProvider implementation.
void GetInterface(const std::string& name,
Expand Down

0 comments on commit aea8d53

Please sign in to comment.