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

Side by Side Diff: extensions/browser/guest_view/extension_view/extension_view_guest.cc

Issue 1658913002: Make extensions use a correct same-origin check. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Respond to comments. Created 4 years, 10 months 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 unified diff | Download patch
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "extensions/browser/guest_view/extension_view/extension_view_guest.h" 5 #include "extensions/browser/guest_view/extension_view/extension_view_guest.h"
6 6
7 #include <utility> 7 #include <utility>
8 8
9 #include "components/crx_file/id_util.h" 9 #include "components/crx_file/id_util.h"
10 #include "components/guest_view/browser/guest_view_event.h" 10 #include "components/guest_view/browser/guest_view_event.h"
11 #include "content/public/browser/render_process_host.h" 11 #include "content/public/browser/render_process_host.h"
12 #include "content/public/common/result_codes.h" 12 #include "content/public/common/result_codes.h"
13 #include "extensions/browser/api/extensions_api_client.h" 13 #include "extensions/browser/api/extensions_api_client.h"
14 #include "extensions/browser/bad_message.h" 14 #include "extensions/browser/bad_message.h"
15 #include "extensions/browser/guest_view/extension_view/extension_view_constants. h" 15 #include "extensions/browser/guest_view/extension_view/extension_view_constants. h"
16 #include "extensions/browser/guest_view/extension_view/whitelist/extension_view_ whitelist.h" 16 #include "extensions/browser/guest_view/extension_view/whitelist/extension_view_ whitelist.h"
17 #include "extensions/common/constants.h" 17 #include "extensions/common/constants.h"
18 #include "extensions/common/extension_messages.h" 18 #include "extensions/common/extension_messages.h"
19 #include "extensions/strings/grit/extensions_strings.h" 19 #include "extensions/strings/grit/extensions_strings.h"
20 #include "url/origin.h"
20 21
21 using content::WebContents; 22 using content::WebContents;
22 using guest_view::GuestViewBase; 23 using guest_view::GuestViewBase;
23 using guest_view::GuestViewEvent; 24 using guest_view::GuestViewEvent;
24 using namespace extensions::api; 25 using namespace extensions::api;
25 26
26 namespace extensions { 27 namespace extensions {
27 28
28 // static 29 // static
29 const char ExtensionViewGuest::Type[] = "extensionview"; 30 const char ExtensionViewGuest::Type[] = "extensionview";
30 31
31 ExtensionViewGuest::ExtensionViewGuest(WebContents* owner_web_contents) 32 ExtensionViewGuest::ExtensionViewGuest(WebContents* owner_web_contents)
32 : GuestView<ExtensionViewGuest>(owner_web_contents) {} 33 : GuestView<ExtensionViewGuest>(owner_web_contents) {}
33 34
34 ExtensionViewGuest::~ExtensionViewGuest() { 35 ExtensionViewGuest::~ExtensionViewGuest() {
35 } 36 }
36 37
37 // static 38 // static
38 GuestViewBase* ExtensionViewGuest::Create(WebContents* owner_web_contents) { 39 GuestViewBase* ExtensionViewGuest::Create(WebContents* owner_web_contents) {
39 return new ExtensionViewGuest(owner_web_contents); 40 return new ExtensionViewGuest(owner_web_contents);
40 } 41 }
41 42
42 bool ExtensionViewGuest::NavigateGuest(const std::string& src, 43 bool ExtensionViewGuest::NavigateGuest(const std::string& src,
43 bool force_navigation) { 44 bool force_navigation) {
44 GURL url = extension_url_.Resolve(src); 45 GURL url = extension_url_.Resolve(src);
45 46
46 // If the URL is not valid, about:blank, or the same origin as the extension, 47 // If the URL is not valid, about:blank, or the same origin as the extension,
47 // then navigate to about:blank. 48 // then navigate to about:blank.
48 bool url_not_allowed = (url != GURL(url::kAboutBlankURL)) && 49 bool url_not_allowed = url != GURL(url::kAboutBlankURL) &&
49 (url.GetOrigin() != extension_url_.GetOrigin()); 50 !url::IsSameOriginWith(url, extension_url_);
50 if (!url.is_valid() || url_not_allowed) 51 if (!url.is_valid() || url_not_allowed)
51 return NavigateGuest(url::kAboutBlankURL, true /* force_navigation */); 52 return NavigateGuest(url::kAboutBlankURL, true /* force_navigation */);
52 53
53 if (!force_navigation && (url_ == url)) 54 if (!force_navigation && (url_ == url))
54 return false; 55 return false;
55 56
56 web_contents()->GetRenderProcessHost()->FilterURL(false, &url); 57 web_contents()->GetRenderProcessHost()->FilterURL(false, &url);
57 web_contents()->GetController().LoadURL(url, content::Referrer(), 58 web_contents()->GetController().LoadURL(url, content::Referrer(),
58 ui::PAGE_TRANSITION_AUTO_TOPLEVEL, 59 ui::PAGE_TRANSITION_AUTO_TOPLEVEL,
59 std::string()); 60 std::string());
(...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after
128 129
129 scoped_ptr<base::DictionaryValue> args(new base::DictionaryValue()); 130 scoped_ptr<base::DictionaryValue> args(new base::DictionaryValue());
130 args->SetString(guest_view::kUrl, url_.spec()); 131 args->SetString(guest_view::kUrl, url_.spec());
131 DispatchEventToView(make_scoped_ptr( 132 DispatchEventToView(make_scoped_ptr(
132 new GuestViewEvent(extensionview::kEventLoadCommit, std::move(args)))); 133 new GuestViewEvent(extensionview::kEventLoadCommit, std::move(args))));
133 } 134 }
134 135
135 void ExtensionViewGuest::DidNavigateMainFrame( 136 void ExtensionViewGuest::DidNavigateMainFrame(
136 const content::LoadCommittedDetails& details, 137 const content::LoadCommittedDetails& details,
137 const content::FrameNavigateParams& params) { 138 const content::FrameNavigateParams& params) {
138 if (attached() && (params.url.GetOrigin() != url_.GetOrigin())) { 139 if (attached() && !url::IsSameOriginWith(params.url, url_)) {
139 bad_message::ReceivedBadMessage(web_contents()->GetRenderProcessHost(), 140 bad_message::ReceivedBadMessage(web_contents()->GetRenderProcessHost(),
140 bad_message::EVG_BAD_ORIGIN); 141 bad_message::EVG_BAD_ORIGIN);
141 } 142 }
142 } 143 }
143 144
144 void ExtensionViewGuest::ApplyAttributes(const base::DictionaryValue& params) { 145 void ExtensionViewGuest::ApplyAttributes(const base::DictionaryValue& params) {
145 std::string src; 146 std::string src;
146 params.GetString(extensionview::kAttributeSrc, &src); 147 params.GetString(extensionview::kAttributeSrc, &src);
147 NavigateGuest(src, false /* force_navigation */); 148 NavigateGuest(src, false /* force_navigation */);
148 } 149 }
149 150
150 } // namespace extensions 151 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698