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

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, 8 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
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 scoped_ptr<base::ListValue> args(new base::ListValue);
95 std::string api_name_utf8 = api_name.utf8();
96 args->Append(ConvertV8Value(api_name_utf8, new_value).release());
97 SendDomActionMessage(
98 api_name_utf8, url, title, DomActionType::SETTER, args.Pass());
99 }
100
101 void DOMActivityLogger::logSetter(const WebString& api_name,
102 const v8::Handle<v8::Value>& new_value,
103 const v8::Handle<v8::Value>& old_value,
104 const WebURL& url,
105 const WebString& title) {
106 scoped_ptr<base::ListValue> args(new base::ListValue);
107 std::string api_name_utf8 = api_name.utf8();
108 args->Append(ConvertV8Value(api_name_utf8, new_value).release());
109 args->Append(ConvertV8Value(api_name_utf8, old_value).release());
110 SendDomActionMessage(
111 api_name_utf8, url, title, DomActionType::SETTER, args.Pass());
112 }
113
114 void DOMActivityLogger::logMethod(const WebString& api_name,
115 int argc,
116 const v8::Handle<v8::Value>* argv,
117 const WebURL& url,
118 const WebString& title) {
119 scoped_ptr<base::ListValue> args(new base::ListValue);
120 std::string api_name_utf8 = api_name.utf8();
121 for (int i = 0; i < argc; ++i)
122 args->Append(ConvertV8Value(api_name_utf8, argv[i]).release());
123 SendDomActionMessage(
124 api_name_utf8, url, title, DomActionType::METHOD, args.Pass());
125 }
126
127 void DOMActivityLogger::SendDomActionMessage(const std::string& api_call,
128 const GURL& url,
129 const base::string16& url_title,
130 DomActionType::Type call_type,
131 scoped_ptr<base::ListValue> args) {
132 ExtensionHostMsg_DOMAction_Params params;
133 params.api_call = api_call;
134 params.url = url;
135 params.url_title = url_title;
136 params.call_type = call_type;
137 params.arguments.Swap(args.get());
138 content::RenderThread::Get()->Send(
139 new ExtensionHostMsg_AddDOMActionToActivityLog(extension_id_, params));
140 }
141
81 } // namespace extensions 142 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698