Skip to content

Commit

Permalink
fix: "Failed to serialize arguments" when emitting 'context-menu' for…
Browse files Browse the repository at this point in the history
… webview (#31259) (#31279)

* fix: sanitize params for 'context-menu' event sent over IPC for webview

* Revert "fix: sanitize params for 'context-menu' event sent over IPC for webview"

This reverts commit 7fee455.

* fix: make frame property non-enumerable in params for 'context-menu' event

Co-authored-by: Milan Burda <milan.burda@gmail.com>
  • Loading branch information
trop[bot] and miniak committed Oct 4, 2021
1 parent 955d6c8 commit e19f7fb
Show file tree
Hide file tree
Showing 2 changed files with 5 additions and 3 deletions.
2 changes: 1 addition & 1 deletion shell/common/gin_converters/content_converter.cc
Expand Up @@ -80,7 +80,7 @@ v8::Local<v8::Value> Converter<ContextMenuParamsWithRenderFrameHost>::ToV8(
const auto& params = val.first;
content::RenderFrameHost* render_frame_host = val.second;
gin_helper::Dictionary dict = gin::Dictionary::CreateEmpty(isolate);
dict.SetGetter("frame", render_frame_host);
dict.SetGetter("frame", render_frame_host, v8::DontEnum);
dict.Set("x", params.x);
dict.Set("y", params.y);
dict.Set("linkURL", params.link_url);
Expand Down
6 changes: 4 additions & 2 deletions shell/common/gin_helper/dictionary.h
Expand Up @@ -111,7 +111,9 @@ class Dictionary : public gin::Dictionary {
}

template <typename K, typename V>
bool SetGetter(const K& key, const V& val) {
bool SetGetter(const K& key,
const V& val,
v8::PropertyAttribute attribute = v8::None) {
AccessorValue<V> acc_value;
acc_value.Value = val;

Expand All @@ -136,7 +138,7 @@ class Dictionary : public gin::Dictionary {
if (gin::TryConvertToV8(info.GetIsolate(), val, &v8_value))
info.GetReturnValue().Set(v8_value);
},
NULL, v8_value_accessor)
nullptr, v8_value_accessor, v8::DEFAULT, attribute)
.ToChecked();
}

Expand Down

0 comments on commit e19f7fb

Please sign in to comment.