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

Side by Side Diff: chrome/browser/guestview/webview/webview_guest.cc

Issue 186213003: <webview>: Context menu API implementation CL. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Sync and address comments. Created 6 years, 9 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 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 "chrome/browser/guestview/webview/webview_guest.h" 5 #include "chrome/browser/guestview/webview/webview_guest.h"
6 6
7 #include "base/strings/stringprintf.h" 7 #include "base/strings/stringprintf.h"
8 #include "chrome/browser/chrome_notification_types.h" 8 #include "chrome/browser/chrome_notification_types.h"
9 #include "chrome/browser/extensions/api/web_request/web_request_api.h" 9 #include "chrome/browser/extensions/api/web_request/web_request_api.h"
10 #include "chrome/browser/extensions/api/webview/webview_api.h" 10 #include "chrome/browser/extensions/api/webview/webview_api.h"
11 #include "chrome/browser/extensions/extension_renderer_state.h" 11 #include "chrome/browser/extensions/extension_renderer_state.h"
12 #include "chrome/browser/extensions/extension_web_contents_observer.h" 12 #include "chrome/browser/extensions/extension_web_contents_observer.h"
13 #include "chrome/browser/extensions/menu_manager.h"
13 #include "chrome/browser/extensions/script_executor.h" 14 #include "chrome/browser/extensions/script_executor.h"
14 #include "chrome/browser/favicon/favicon_tab_helper.h" 15 #include "chrome/browser/favicon/favicon_tab_helper.h"
15 #include "chrome/browser/guestview/guestview_constants.h" 16 #include "chrome/browser/guestview/guestview_constants.h"
16 #include "chrome/browser/guestview/webview/webview_constants.h" 17 #include "chrome/browser/guestview/webview/webview_constants.h"
17 #include "chrome/browser/guestview/webview/webview_permission_types.h" 18 #include "chrome/browser/guestview/webview/webview_permission_types.h"
18 #include "chrome/common/chrome_version_info.h" 19 #include "chrome/common/chrome_version_info.h"
19 #include "content/public/browser/browser_thread.h" 20 #include "content/public/browser/browser_thread.h"
20 #include "content/public/browser/native_web_keyboard_event.h" 21 #include "content/public/browser/native_web_keyboard_event.h"
21 #include "content/public/browser/navigation_entry.h" 22 #include "content/public/browser/navigation_entry.h"
22 #include "content/public/browser/notification_details.h" 23 #include "content/public/browser/notification_details.h"
(...skipping 139 matching lines...) Expand 10 before | Expand all | Expand 10 after
162 return NULL; 163 return NULL;
163 return guest->AsWebView(); 164 return guest->AsWebView();
164 } 165 }
165 166
166 // static 167 // static
167 WebViewGuest* WebViewGuest::FromWebContents(WebContents* contents) { 168 WebViewGuest* WebViewGuest::FromWebContents(WebContents* contents) {
168 GuestView* guest = GuestView::FromWebContents(contents); 169 GuestView* guest = GuestView::FromWebContents(contents);
169 return guest ? guest->AsWebView() : NULL; 170 return guest ? guest->AsWebView() : NULL;
170 } 171 }
171 172
173 // static.
174 int WebViewGuest::GetViewInstanceId(WebContents* contents) {
175 GuestView* guest = GuestView::FromWebContents(contents);
Fady Samuel 2014/03/04 16:36:00 A small simplification: WebViewGuest* guest = Fro
lazyboy 2014/03/04 20:50:24 Done, thanks.
176 if (!guest || !guest->AsWebView())
177 return guestview::kInstanceIDNone;
178
179 return guest->view_instance_id();
180 }
181
172 // static 182 // static
173 void WebViewGuest::RecordUserInitiatedUMA(const PermissionResponseInfo& info, 183 void WebViewGuest::RecordUserInitiatedUMA(const PermissionResponseInfo& info,
174 bool allow) { 184 bool allow) {
175 if (allow) { 185 if (allow) {
176 // Note that |allow| == true means the embedder explicitly allowed the 186 // Note that |allow| == true means the embedder explicitly allowed the
177 // request. For some requests they might still fail. An example of such 187 // request. For some requests they might still fail. An example of such
178 // scenario would be: an embedder allows geolocation request but doesn't 188 // scenario would be: an embedder allows geolocation request but doesn't
179 // have geolocation access on its own. 189 // have geolocation access on its own.
180 switch (info.permission_type) { 190 switch (info.permission_type) {
181 case BROWSER_PLUGIN_PERMISSION_TYPE_DOWNLOAD: 191 case BROWSER_PLUGIN_PERMISSION_TYPE_DOWNLOAD:
(...skipping 493 matching lines...) Expand 10 before | Expand all | Expand 10 after
675 if (frame_id == main_frame_id_) 685 if (frame_id == main_frame_id_)
676 InjectChromeVoxIfNeeded(render_view_host); 686 InjectChromeVoxIfNeeded(render_view_host);
677 } 687 }
678 688
679 void WebViewGuest::DidStopLoading(content::RenderViewHost* render_view_host) { 689 void WebViewGuest::DidStopLoading(content::RenderViewHost* render_view_host) {
680 scoped_ptr<base::DictionaryValue> args(new base::DictionaryValue()); 690 scoped_ptr<base::DictionaryValue> args(new base::DictionaryValue());
681 DispatchEvent(new GuestView::Event(webview::kEventLoadStop, args.Pass())); 691 DispatchEvent(new GuestView::Event(webview::kEventLoadStop, args.Pass()));
682 } 692 }
683 693
684 void WebViewGuest::WebContentsDestroyed(WebContents* web_contents) { 694 void WebViewGuest::WebContentsDestroyed(WebContents* web_contents) {
695 // Clean up custom context menu items for this guest.
696 extensions::MenuManager* menu_manager = extensions::MenuManager::Get(
697 Profile::FromBrowserContext(browser_context()));
698 menu_manager->RemoveAllWebviewContextItems(extension_id(),
699 view_instance_id());
700
685 RemoveWebViewFromExtensionRendererState(web_contents); 701 RemoveWebViewFromExtensionRendererState(web_contents);
686 } 702 }
687 703
688 void WebViewGuest::UserAgentOverrideSet(const std::string& user_agent) { 704 void WebViewGuest::UserAgentOverrideSet(const std::string& user_agent) {
689 content::NavigationController& controller = 705 content::NavigationController& controller =
690 guest_web_contents()->GetController(); 706 guest_web_contents()->GetController();
691 content::NavigationEntry* entry = controller.GetVisibleEntry(); 707 content::NavigationEntry* entry = controller.GetVisibleEntry();
692 if (!entry) 708 if (!entry)
693 return; 709 return;
694 entry->SetIsOverridingUserAgent(!user_agent.empty()); 710 entry->SetIsOverridingUserAgent(!user_agent.empty());
(...skipping 118 matching lines...) Expand 10 before | Expand all | Expand 10 after
813 const PermissionResponseCallback& callback, 829 const PermissionResponseCallback& callback,
814 BrowserPluginPermissionType permission_type, 830 BrowserPluginPermissionType permission_type,
815 bool allowed_by_default) 831 bool allowed_by_default)
816 : callback(callback), 832 : callback(callback),
817 permission_type(permission_type), 833 permission_type(permission_type),
818 allowed_by_default(allowed_by_default) { 834 allowed_by_default(allowed_by_default) {
819 } 835 }
820 836
821 WebViewGuest::PermissionResponseInfo::~PermissionResponseInfo() { 837 WebViewGuest::PermissionResponseInfo::~PermissionResponseInfo() {
822 } 838 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698