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

Side by Side Diff: chrome/renderer/extensions/dom_activity_logger.cc

Issue 247953008: Extend DOMActivityLogger interface for upcoming change (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 7 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 | Annotate | Revision Log
« no previous file with comments | « chrome/renderer/extensions/dom_activity_logger.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. 1 // Copyright (c) 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/renderer/extensions/dom_activity_logger.h" 5 #include "chrome/renderer/extensions/dom_activity_logger.h"
6 6
7 #include "chrome/common/extensions/ad_injection_constants.h" 7 #include "chrome/common/extensions/ad_injection_constants.h"
8 #include "chrome/common/extensions/dom_action_types.h"
9 #include "chrome/renderer/chrome_render_process_observer.h" 8 #include "chrome/renderer/chrome_render_process_observer.h"
10 #include "chrome/renderer/extensions/activity_log_converter_strategy.h" 9 #include "chrome/renderer/extensions/activity_log_converter_strategy.h"
11 #include "content/public/renderer/render_thread.h" 10 #include "content/public/renderer/render_thread.h"
12 #include "content/public/renderer/v8_value_converter.h" 11 #include "content/public/renderer/v8_value_converter.h"
13 #include "extensions/common/extension_messages.h" 12 #include "extensions/common/extension_messages.h"
14 #include "third_party/WebKit/public/platform/WebString.h" 13 #include "third_party/WebKit/public/platform/WebString.h"
15 #include "third_party/WebKit/public/platform/WebURL.h" 14 #include "third_party/WebKit/public/platform/WebURL.h"
16 #include "third_party/WebKit/public/web/WebDOMActivityLogger.h" 15 #include "third_party/WebKit/public/web/WebDOMActivityLogger.h"
17 #include "v8/include/v8.h" 16 #include "v8/include/v8.h"
18 17
19 using content::V8ValueConverter; 18 using content::V8ValueConverter;
20 using blink::WebString; 19 using blink::WebString;
21 using blink::WebURL; 20 using blink::WebURL;
22 21
23 namespace extensions { 22 namespace extensions {
24 23
24 namespace {
25
26 scoped_ptr<base::Value> ConvertV8Value(const std::string& api_name,
27 const v8::Handle<v8::Value> v8_value) {
28 scoped_ptr<V8ValueConverter> converter(V8ValueConverter::create());
29 ActivityLogConverterStrategy strategy;
30 strategy.set_enable_detailed_parsing(
31 ad_injection_constants::ApiCanInjectAds(api_name));
32 converter->SetFunctionAllowed(true);
33 converter->SetStrategy(&strategy);
34 return scoped_ptr<base::Value>(converter->FromV8Value(
35 v8_value, v8::Isolate::GetCurrent()->GetCurrentContext()));
36 }
37
38 } // namespace
39
25 DOMActivityLogger::DOMActivityLogger(const std::string& extension_id) 40 DOMActivityLogger::DOMActivityLogger(const std::string& extension_id)
26 : extension_id_(extension_id) { 41 : extension_id_(extension_id) {
27 } 42 }
28 43
29 DOMActivityLogger::~DOMActivityLogger() {} 44 DOMActivityLogger::~DOMActivityLogger() {}
30 45
31 void DOMActivityLogger::log( 46 void DOMActivityLogger::log(
32 const WebString& api_name, 47 const WebString& api_name,
33 int argc, 48 int argc,
34 const v8::Handle<v8::Value> argv[], 49 const v8::Handle<v8::Value> argv[],
35 const WebString& call_type, 50 const WebString& call_type,
36 const WebURL& url, 51 const WebURL& url,
37 const WebString& title) { 52 const WebString& title) {
38 scoped_ptr<V8ValueConverter> converter(V8ValueConverter::create()); 53 scoped_ptr<base::ListValue> args(new base::ListValue());
39 ActivityLogConverterStrategy strategy; 54 std::string api_name_utf8 = api_name.utf8();
40 strategy.set_enable_detailed_parsing( 55 for (int i = 0; i < argc; ++i)
41 ad_injection_constants::ApiCanInjectAds(api_name.utf8().c_str())); 56 args->Append(ConvertV8Value(api_name_utf8, argv[i]).release());
42 converter->SetFunctionAllowed(true);
43 converter->SetStrategy(&strategy);
44 scoped_ptr<base::ListValue> argv_list_value(new base::ListValue());
45 for (int i = 0; i < argc; i++) {
46 argv_list_value->Set(
47 i,
48 converter->FromV8Value(argv[i],
49 v8::Isolate::GetCurrent()->GetCurrentContext()));
50 }
51 57
52 ExtensionHostMsg_DOMAction_Params params; 58 DomActionType::Type type = DomActionType::METHOD;
53 params.url = url; 59 if (call_type == "Getter")
54 params.url_title = title; 60 type = DomActionType::GETTER;
55 params.api_call = api_name.utf8(); 61 else if (call_type == "Setter")
56 params.arguments.Swap(argv_list_value.get()); 62 type = DomActionType::SETTER;
57 const std::string type = call_type.utf8(); 63 // else DomActionType::METHOD is correct.
58 if (type == "Getter") 64 SendDomActionMessage(
59 params.call_type = DomActionType::GETTER; 65 api_name_utf8, url, title, type, args.Pass());
60 else if (type == "Setter")
61 params.call_type = DomActionType::SETTER;
62 else
63 params.call_type = DomActionType::METHOD;
64
65 content::RenderThread::Get()->Send(
66 new ExtensionHostMsg_AddDOMActionToActivityLog(extension_id_, params));
67 } 66 }
68 67
69 void DOMActivityLogger::AttachToWorld(int world_id, 68 void DOMActivityLogger::AttachToWorld(int world_id,
70 const std::string& extension_id) { 69 const std::string& extension_id) {
71 #if defined(ENABLE_EXTENSIONS) 70 #if defined(ENABLE_EXTENSIONS)
72 // If there is no logger registered for world_id, construct a new logger 71 // If there is no logger registered for world_id, construct a new logger
73 // and register it with world_id. 72 // and register it with world_id.
74 if (!blink::hasDOMActivityLogger(world_id)) { 73 if (!blink::hasDOMActivityLogger(world_id)) {
75 DOMActivityLogger* logger = new DOMActivityLogger(extension_id); 74 DOMActivityLogger* logger = new DOMActivityLogger(extension_id);
76 blink::setDOMActivityLogger(world_id, logger); 75 blink::setDOMActivityLogger(world_id, logger);
77 } 76 }
78 #endif 77 #endif
79 } 78 }
80 79
80 void DOMActivityLogger::logGetter(const WebString& api_name,
81 const WebURL& url,
82 const WebString& title) {
83 SendDomActionMessage(api_name.utf8(),
84 url,
85 title,
86 DomActionType::GETTER,
87 scoped_ptr<base::ListValue>(new base::ListValue()));
88 }
89
90 void DOMActivityLogger::logSetter(const WebString& api_name,
91 const v8::Handle<v8::Value>& new_value,
92 const WebURL& url,
93 const WebString& title) {
94 logSetter(api_name, new_value, v8::Handle<v8::Value>(), url, title);
not at google - send to devlin 2014/04/24 20:38:51 not convinced this method is really useful, caller
95 }
96
97 void DOMActivityLogger::logSetter(const WebString& api_name,
98 const v8::Handle<v8::Value>& new_value,
99 const v8::Handle<v8::Value>& old_value,
100 const WebURL& url,
101 const WebString& title) {
102 scoped_ptr<base::ListValue> args(new base::ListValue);
103 std::string api_name_utf8 = api_name.utf8();
104 args->Append(ConvertV8Value(api_name_utf8, new_value).release());
105 if (!old_value.IsEmpty())
106 args->Append(ConvertV8Value(api_name_utf8, old_value).release());
107 SendDomActionMessage(
108 api_name_utf8, url, title, DomActionType::SETTER, args.Pass());
109 }
110
111 void DOMActivityLogger::logMethod(const WebString& api_name,
112 int argc,
113 const v8::Handle<v8::Value>* argv,
114 const WebURL& url,
115 const WebString& title) {
116 scoped_ptr<base::ListValue> args(new base::ListValue);
117 std::string api_name_utf8 = api_name.utf8();
118 for (int i = 0; i < argc; ++i)
119 args->Append(ConvertV8Value(api_name_utf8, argv[i]).release());
120 SendDomActionMessage(
121 api_name_utf8, url, title, DomActionType::METHOD, args.Pass());
122 }
123
124 void DOMActivityLogger::SendDomActionMessage(const std::string& api_call,
125 const GURL& url,
126 const base::string16& url_title,
127 DomActionType::Type call_type,
128 scoped_ptr<base::ListValue> args) {
129 ExtensionHostMsg_DOMAction_Params params;
130 params.api_call = api_call;
131 params.url = url;
132 params.url_title = url_title;
133 params.call_type = call_type;
134 params.arguments.Swap(args.get());
135 content::RenderThread::Get()->Send(
136 new ExtensionHostMsg_AddDOMActionToActivityLog(extension_id_, params));
137 }
138
81 } // namespace extensions 139 } // namespace extensions
OLDNEW
« no previous file with comments | « chrome/renderer/extensions/dom_activity_logger.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698