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

Side by Side Diff: chrome/browser/guest_view/extension_options/extension_options_guest.cc

Issue 378783002: Initial implementation of the <extensionoptions> GuestView tag (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Address Devlin's comments, fix style Created 6 years, 5 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
(Empty)
1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "chrome/browser/guest_view/extension_options/extension_options_guest.h"
6
7 #include "chrome/browser/extensions/chrome_extension_web_contents_observer.h"
8 #include "chrome/browser/guest_view/extension_options/extension_options_constant s.h"
9 #include "chrome/browser/profiles/profile.h"
10 #include "chrome/common/extensions/manifest_url_handler.h"
11 #include "content/public/browser/render_process_host.h"
12 #include "content/public/browser/site_instance.h"
13 #include "content/public/browser/web_contents.h"
14 #include "extensions/browser/extension_function_dispatcher.h"
15 #include "extensions/browser/extension_registry.h"
16 #include "extensions/common/extension.h"
17 #include "extensions/common/extension_messages.h"
18 #include "extensions/common/permissions/permissions_data.h"
19 #include "ipc/ipc_message_macros.h"
20
21 using content::WebContents;
22
23 // static
24 const char ExtensionOptionsGuest::Type[] = "extensionoptions";
25
26 ExtensionOptionsGuest::ExtensionOptionsGuest(
27 content::BrowserContext* browser_context,
28 int guest_instance_id)
29 : GuestView<ExtensionOptionsGuest>(browser_context, guest_instance_id) {
30 }
31
32 ExtensionOptionsGuest::~ExtensionOptionsGuest() {
33 }
34
35 bool ExtensionOptionsGuest::CanEmbedderUseGuestView(
36 const std::string& embedder_extension_id) {
37 extensions::ExtensionRegistry* registry =
Devlin 2014/07/17 20:05:09 nit: to me, this looks a bit excessive with the va
ericzeng 2014/07/17 23:14:47 I'll create a variable just for the extension, and
38 extensions::ExtensionRegistry::Get(browser_context());
39 const extensions::Extension* embedder_extension =
40 registry->enabled_extensions().GetByID(embedder_extension_id);
41 const extensions::PermissionsData* permissions_data =
42 embedder_extension->permissions_data();
43 return permissions_data->HasAPIPermission(
44 extensions::APIPermission::kEmbeddedExtensionOptions);
45 }
46
47 void ExtensionOptionsGuest::CreateWebContents(
48 const std::string& embedder_extension_id,
49 int embedder_render_process_id,
50 const base::DictionaryValue& create_params,
51 const WebContentsCreatedCallback& callback) {
52 content::RenderProcessHost* embedder_render_process_host =
Devlin 2014/07/17 20:05:09 nit: Can we inline these? content::BrowserContext
ericzeng 2014/07/17 23:14:47 Done.
53 content::RenderProcessHost::FromID(embedder_render_process_id);
54 content::BrowserContext* browser_context =
55 embedder_render_process_host->GetBrowserContext();
56
57 // Get the extension's base URL.
58 std::string extension_id;
59 create_params.GetString(extensionoptions::kExtensionId, &extension_id);
60 if (extension_id.empty()) {
61 callback.Run(NULL);
62 return;
63 }
Devlin 2014/07/17 20:05:09 Maybe a DCHECK(Extension::IdIsValid(extension_id))
ericzeng 2014/07/17 23:14:47 Done.
64 GURL extension_url =
65 extensions::Extension::GetBaseURLFromExtensionId(extension_id);
66 if (!extension_url.is_valid()) {
67 callback.Run(NULL);
68 return;
69 }
70
71 // Get the options page URL for later use.
72 extensions::ExtensionRegistry* registry =
73 extensions::ExtensionRegistry::Get(browser_context);
74 const extensions::Extension* extension =
75 registry->enabled_extensions().GetByID(extension_id);
76 options_page_ = extensions::ManifestURL::GetOptionsPage(extension);
77 if (!options_page_.is_valid()) {
78 callback.Run(NULL);
79 return;
80 }
81
82 // Create a Webcontents using the extension URL.
83 content::SiteInstance* options_site_instance =
84 content::SiteInstance::CreateForURL(browser_context, extension_url);
85 WebContents::CreateParams params(browser_context, options_site_instance);
86 params.guest_delegate = this;
87 callback.Run(WebContents::Create(params));
88 }
89
90 void ExtensionOptionsGuest::DidAttachToEmbedder() {
91 guest_web_contents()->GetController().LoadURL(options_page_,
92 content::Referrer(),
93 content::PAGE_TRANSITION_LINK,
94 std::string());
95 }
96
97 void ExtensionOptionsGuest::DidInitialize() {
98 extension_function_dispatcher_.reset(
99 new extensions::ExtensionFunctionDispatcher(browser_context(), this));
100 extensions::ChromeExtensionWebContentsObserver::CreateForWebContents(
101 guest_web_contents());
102 }
103
104 content::WebContents* ExtensionOptionsGuest::GetAssociatedWebContents() const {
105 return guest_web_contents();
106 }
107
108 bool ExtensionOptionsGuest::OnMessageReceived(const IPC::Message& message) {
109 bool handled = true;
110 IPC_BEGIN_MESSAGE_MAP(ExtensionOptionsGuest, message)
111 IPC_MESSAGE_HANDLER(ExtensionHostMsg_Request, OnRequest)
Devlin 2014/07/17 20:05:09 nit: git cl format will undo this, but I think tha
ericzeng 2014/07/17 23:14:47 Yeah, it looks like I undid the indentation with g
112 IPC_MESSAGE_UNHANDLED(handled = false)
113 IPC_END_MESSAGE_MAP()
114 return handled;
115 }
116
117 void ExtensionOptionsGuest::OnRequest(
118 const ExtensionHostMsg_Request_Params& params) {
119 extension_function_dispatcher_->Dispatch(
120 params, guest_web_contents()->GetRenderViewHost());
121 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698