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

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

Issue 259003005: Revert 266157 "Extend DOMActivityLogger interface for upcoming c..." (Closed) Base URL: svn://svn.chromium.org/chrome/
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 | « trunk/src/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"
8 #include "chrome/renderer/chrome_render_process_observer.h" 9 #include "chrome/renderer/chrome_render_process_observer.h"
9 #include "chrome/renderer/extensions/activity_log_converter_strategy.h" 10 #include "chrome/renderer/extensions/activity_log_converter_strategy.h"
10 #include "content/public/renderer/render_thread.h" 11 #include "content/public/renderer/render_thread.h"
11 #include "content/public/renderer/v8_value_converter.h" 12 #include "content/public/renderer/v8_value_converter.h"
12 #include "extensions/common/extension_messages.h" 13 #include "extensions/common/extension_messages.h"
13 #include "third_party/WebKit/public/platform/WebString.h" 14 #include "third_party/WebKit/public/platform/WebString.h"
14 #include "third_party/WebKit/public/platform/WebURL.h" 15 #include "third_party/WebKit/public/platform/WebURL.h"
15 #include "third_party/WebKit/public/web/WebDOMActivityLogger.h" 16 #include "third_party/WebKit/public/web/WebDOMActivityLogger.h"
16 #include "v8/include/v8.h" 17 #include "v8/include/v8.h"
17 18
18 using content::V8ValueConverter; 19 using content::V8ValueConverter;
19 using blink::WebString; 20 using blink::WebString;
20 using blink::WebURL; 21 using blink::WebURL;
21 22
22 namespace extensions { 23 namespace extensions {
23 24
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
40 DOMActivityLogger::DOMActivityLogger(const std::string& extension_id) 25 DOMActivityLogger::DOMActivityLogger(const std::string& extension_id)
41 : extension_id_(extension_id) { 26 : extension_id_(extension_id) {
42 } 27 }
43 28
44 DOMActivityLogger::~DOMActivityLogger() {} 29 DOMActivityLogger::~DOMActivityLogger() {}
45 30
46 void DOMActivityLogger::log( 31 void DOMActivityLogger::log(
47 const WebString& api_name, 32 const WebString& api_name,
48 int argc, 33 int argc,
49 const v8::Handle<v8::Value> argv[], 34 const v8::Handle<v8::Value> argv[],
50 const WebString& call_type, 35 const WebString& call_type,
51 const WebURL& url, 36 const WebURL& url,
52 const WebString& title) { 37 const WebString& title) {
53 scoped_ptr<base::ListValue> args(new base::ListValue()); 38 scoped_ptr<V8ValueConverter> converter(V8ValueConverter::create());
54 std::string api_name_utf8 = api_name.utf8(); 39 ActivityLogConverterStrategy strategy;
55 for (int i = 0; i < argc; ++i) 40 strategy.set_enable_detailed_parsing(
56 args->Append(ConvertV8Value(api_name_utf8, argv[i]).release()); 41 ad_injection_constants::ApiCanInjectAds(api_name.utf8().c_str()));
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 }
57 51
58 DomActionType::Type type = DomActionType::METHOD; 52 ExtensionHostMsg_DOMAction_Params params;
59 if (call_type == "Getter") 53 params.url = url;
60 type = DomActionType::GETTER; 54 params.url_title = title;
61 else if (call_type == "Setter") 55 params.api_call = api_name.utf8();
62 type = DomActionType::SETTER; 56 params.arguments.Swap(argv_list_value.get());
63 // else DomActionType::METHOD is correct. 57 const std::string type = call_type.utf8();
64 SendDomActionMessage( 58 if (type == "Getter")
65 api_name_utf8, url, title, type, args.Pass()); 59 params.call_type = DomActionType::GETTER;
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));
66 } 67 }
67 68
68 void DOMActivityLogger::AttachToWorld(int world_id, 69 void DOMActivityLogger::AttachToWorld(int world_id,
69 const std::string& extension_id) { 70 const std::string& extension_id) {
70 #if defined(ENABLE_EXTENSIONS) 71 #if defined(ENABLE_EXTENSIONS)
71 // If there is no logger registered for world_id, construct a new logger 72 // If there is no logger registered for world_id, construct a new logger
72 // and register it with world_id. 73 // and register it with world_id.
73 if (!blink::hasDOMActivityLogger(world_id)) { 74 if (!blink::hasDOMActivityLogger(world_id)) {
74 DOMActivityLogger* logger = new DOMActivityLogger(extension_id); 75 DOMActivityLogger* logger = new DOMActivityLogger(extension_id);
75 blink::setDOMActivityLogger(world_id, logger); 76 blink::setDOMActivityLogger(world_id, logger);
76 } 77 }
77 #endif 78 #endif
78 } 79 }
79 80
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);
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
139 } // namespace extensions 81 } // namespace extensions
OLDNEW
« no previous file with comments | « trunk/src/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