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

Side by Side Diff: extensions/browser/guest_view/worker_frame/worker_frame_guest.cc

Issue 820513002: Renamed WorkerFrame to SurfaceWorker (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fixed tests Created 6 years 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 "extensions/browser/guest_view/worker_frame/worker_frame_guest.h"
6
7 #include "content/public/common/url_constants.h"
8 #include "extensions/browser/guest_view/guest_view_manager.h"
9 #include "extensions/browser/guest_view/worker_frame/worker_frame_constants.h"
10 #include "extensions/strings/grit/extensions_strings.h"
11 #include "ipc/ipc_message_macros.h"
12
13 using content::RenderFrameHost;
14 using content::WebContents;
15
16 namespace extensions {
17
18 // static.
19 const char WorkerFrameGuest::Type[] = "workerframe";
20
21 // static
22 GuestViewBase* WorkerFrameGuest::Create(
23 content::BrowserContext* browser_context,
24 content::WebContents* owner_web_contents,
25 int guest_instance_id) {
26 return new WorkerFrameGuest(browser_context,
27 owner_web_contents,
28 guest_instance_id);
29 }
30
31 WorkerFrameGuest::WorkerFrameGuest(
32 content::BrowserContext* browser_context,
33 content::WebContents* owner_web_contents,
34 int guest_instance_id)
35 : GuestView<WorkerFrameGuest>(browser_context,
36 owner_web_contents,
37 guest_instance_id),
38 weak_ptr_factory_(this) {
39 }
40
41 WorkerFrameGuest::~WorkerFrameGuest() {
42 }
43
44 bool WorkerFrameGuest::HandleContextMenu(
45 const content::ContextMenuParams& params) {
46 return false;
47 }
48
49 const char* WorkerFrameGuest::GetAPINamespace() const {
50 return worker_frame::kEmbedderAPINamespace;
51 }
52
53 int WorkerFrameGuest::GetTaskPrefix() const {
54 return IDS_EXTENSION_TASK_MANAGER_WORKER_FRAME_TAG_PREFIX;
55 }
56
57 void WorkerFrameGuest::CreateWebContents(
58 const base::DictionaryValue& create_params,
59 const WebContentsCreatedCallback& callback) {
60 std::string url;
61 if (!create_params.GetString(worker_frame::kURL, &url)) {
62 callback.Run(NULL);
63 return;
64 }
65
66 url_ = GURL(url);
67 if (!url_.is_valid()) {
68 callback.Run(NULL);
69 return;
70 }
71
72 GURL guest_site(base::StringPrintf("%s://wtf-%s",
73 content::kGuestScheme,
74 GetOwnerSiteURL().host().c_str()));
75
76 GuestViewManager* guest_view_manager =
77 GuestViewManager::FromBrowserContext(
78 owner_web_contents()->GetBrowserContext());
79 content::SiteInstance* guest_site_instance =
80 guest_view_manager->GetGuestSiteInstance(guest_site);
81 WebContents::CreateParams params(
82 owner_web_contents()->GetBrowserContext(),
83 guest_site_instance);
84 params.guest_delegate = this;
85 callback.Run(WebContents::Create(params));
86 }
87
88 void WorkerFrameGuest::DidAttachToEmbedder() {
89 web_contents()->GetController().LoadURL(
90 url_, content::Referrer(), ui::PAGE_TRANSITION_LINK, std::string());
91 url_ = GURL();
92 }
93
94 } // namespace extensions
OLDNEW
« no previous file with comments | « extensions/browser/guest_view/worker_frame/worker_frame_guest.h ('k') | extensions/common/api/_api_features.json » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698