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

Side by Side Diff: extensions/browser/guest_view/extensions_guest_view_manager_delegate.cc

Issue 1272373003: Add extension event histogram values for messaging, webRequest, and webview. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: last Created 5 years, 4 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/extensions_guest_view_manager_delegate.h " 5 #include "extensions/browser/guest_view/extensions_guest_view_manager_delegate.h "
6 6
7 #include "components/guest_view/browser/guest_view_base.h" 7 #include "components/guest_view/browser/guest_view_base.h"
8 #include "components/guest_view/browser/guest_view_manager.h" 8 #include "components/guest_view/browser/guest_view_manager.h"
9 #include "components/guest_view/common/guest_view_constants.h"
9 #include "content/public/browser/browser_context.h" 10 #include "content/public/browser/browser_context.h"
10 #include "content/public/browser/render_process_host.h" 11 #include "content/public/browser/render_process_host.h"
11 #include "extensions/browser/api/extensions_api_client.h" 12 #include "extensions/browser/api/extensions_api_client.h"
12 #include "extensions/browser/event_router.h" 13 #include "extensions/browser/event_router.h"
13 #include "extensions/browser/guest_view/app_view/app_view_guest.h" 14 #include "extensions/browser/guest_view/app_view/app_view_guest.h"
14 #include "extensions/browser/guest_view/extension_options/extension_options_gues t.h" 15 #include "extensions/browser/guest_view/extension_options/extension_options_gues t.h"
15 #include "extensions/browser/guest_view/extension_view/extension_view_guest.h" 16 #include "extensions/browser/guest_view/extension_view/extension_view_guest.h"
17 #include "extensions/browser/guest_view/guest_view_events.h"
16 #include "extensions/browser/guest_view/mime_handler_view/mime_handler_view_gues t.h" 18 #include "extensions/browser/guest_view/mime_handler_view/mime_handler_view_gues t.h"
17 #include "extensions/browser/guest_view/surface_worker/surface_worker_guest.h" 19 #include "extensions/browser/guest_view/surface_worker/surface_worker_guest.h"
18 #include "extensions/browser/guest_view/web_view/web_view_guest.h" 20 #include "extensions/browser/guest_view/web_view/web_view_guest.h"
19 #include "extensions/browser/process_manager.h" 21 #include "extensions/browser/process_manager.h"
20 #include "extensions/browser/process_map.h" 22 #include "extensions/browser/process_map.h"
21 #include "extensions/common/features/feature.h" 23 #include "extensions/common/features/feature.h"
22 #include "extensions/common/features/feature_provider.h" 24 #include "extensions/common/features/feature_provider.h"
23 25
24 using guest_view::GuestViewBase; 26 using guest_view::GuestViewBase;
25 using guest_view::GuestViewManager; 27 using guest_view::GuestViewManager;
(...skipping 11 matching lines...) Expand all
37 void ExtensionsGuestViewManagerDelegate::DispatchEvent( 39 void ExtensionsGuestViewManagerDelegate::DispatchEvent(
38 const std::string& event_name, 40 const std::string& event_name,
39 scoped_ptr<base::DictionaryValue> args, 41 scoped_ptr<base::DictionaryValue> args,
40 GuestViewBase* guest, 42 GuestViewBase* guest,
41 int instance_id) { 43 int instance_id) {
42 EventFilteringInfo info; 44 EventFilteringInfo info;
43 info.SetInstanceID(instance_id); 45 info.SetInstanceID(instance_id);
44 scoped_ptr<base::ListValue> event_args(new base::ListValue()); 46 scoped_ptr<base::ListValue> event_args(new base::ListValue());
45 event_args->Append(args.release()); 47 event_args->Append(args.release());
46 48
47 EventRouter::DispatchEvent( 49 // GetEventHistogramValue maps guest view event names to their histogram
48 guest->owner_web_contents(), 50 // value. It needs to be like this because the guest view component doesn't
49 guest->browser_context(), 51 // know about extensions, so GuestViewEvent can't have an
50 guest->owner_host(), 52 // extensions::events::HistogramValue as an argument.
51 event_name, 53 events::HistogramValue histogram_value =
52 event_args.Pass(), 54 guest_view_events::GetEventHistogramValue(event_name);
53 EventRouter::USER_GESTURE_UNKNOWN, 55 DCHECK_NE(events::UNKNOWN, histogram_value) << "Event " << event_name
54 info); 56 << " must have a histogram value";
57
58 content::WebContents* owner = guest->owner_web_contents();
59 EventRouter::DispatchEventToSender(
60 owner, guest->browser_context(), guest->owner_host(), histogram_value,
61 event_name, event_args.Pass(), EventRouter::USER_GESTURE_UNKNOWN, info);
55 } 62 }
56 63
57 bool ExtensionsGuestViewManagerDelegate::IsGuestAvailableToContext( 64 bool ExtensionsGuestViewManagerDelegate::IsGuestAvailableToContext(
58 GuestViewBase* guest) { 65 GuestViewBase* guest) {
59 const Feature* feature = 66 const Feature* feature =
60 FeatureProvider::GetAPIFeature(guest->GetAPINamespace()); 67 FeatureProvider::GetAPIFeature(guest->GetAPINamespace());
61 CHECK(feature); 68 CHECK(feature);
62 69
63 ProcessMap* process_map = ProcessMap::Get(context_); 70 ProcessMap* process_map = ProcessMap::Get(context_);
64 CHECK(process_map); 71 CHECK(process_map);
(...skipping 22 matching lines...) Expand all
87 GuestViewManager* manager = GuestViewManager::FromBrowserContext(context_); 94 GuestViewManager* manager = GuestViewManager::FromBrowserContext(context_);
88 manager->RegisterGuestViewType<AppViewGuest>(); 95 manager->RegisterGuestViewType<AppViewGuest>();
89 manager->RegisterGuestViewType<ExtensionOptionsGuest>(); 96 manager->RegisterGuestViewType<ExtensionOptionsGuest>();
90 manager->RegisterGuestViewType<ExtensionViewGuest>(); 97 manager->RegisterGuestViewType<ExtensionViewGuest>();
91 manager->RegisterGuestViewType<MimeHandlerViewGuest>(); 98 manager->RegisterGuestViewType<MimeHandlerViewGuest>();
92 manager->RegisterGuestViewType<SurfaceWorkerGuest>(); 99 manager->RegisterGuestViewType<SurfaceWorkerGuest>();
93 manager->RegisterGuestViewType<WebViewGuest>(); 100 manager->RegisterGuestViewType<WebViewGuest>();
94 } 101 }
95 102
96 } // namespace extensions 103 } // namespace extensions
OLDNEW
« no previous file with comments | « extensions/browser/extension_event_histogram_value.h ('k') | extensions/browser/guest_view/guest_view_events.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698