| OLD | NEW |
| 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/browser/extensions/activity_log/activity_actions.h" | 5 #include "chrome/browser/extensions/activity_log/activity_actions.h" |
| 6 | 6 |
| 7 #include <algorithm> // for std::find. | 7 #include <algorithm> // for std::find. |
| 8 #include <string> | 8 #include <string> |
| 9 | 9 |
| 10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
| (...skipping 13 matching lines...) Expand all Loading... |
| 24 #include "chrome/browser/ui/browser.h" | 24 #include "chrome/browser/ui/browser.h" |
| 25 #include "chrome/common/chrome_switches.h" | 25 #include "chrome/common/chrome_switches.h" |
| 26 #include "components/rappor/rappor_service.h" | 26 #include "components/rappor/rappor_service.h" |
| 27 #include "content/public/browser/web_contents.h" | 27 #include "content/public/browser/web_contents.h" |
| 28 #include "extensions/common/constants.h" | 28 #include "extensions/common/constants.h" |
| 29 #include "extensions/common/dom_action_types.h" | 29 #include "extensions/common/dom_action_types.h" |
| 30 #include "sql/statement.h" | 30 #include "sql/statement.h" |
| 31 #include "url/gurl.h" | 31 #include "url/gurl.h" |
| 32 | 32 |
| 33 namespace constants = activity_log_constants; | 33 namespace constants = activity_log_constants; |
| 34 namespace activity_log = extensions::api::activity_log_private; |
| 34 | 35 |
| 35 namespace extensions { | 36 namespace extensions { |
| 36 | 37 |
| 37 namespace { | 38 namespace { |
| 38 | 39 |
| 39 // The "Extensions.PossibleAdInjection2" metric uses different Rappor | 40 // The "Extensions.PossibleAdInjection2" metric uses different Rappor |
| 40 // parameters than the original metric. | 41 // parameters than the original metric. |
| 41 const char kExtensionAdInjectionRapporMetricName[] = | 42 const char kExtensionAdInjectionRapporMetricName[] = |
| 42 "Extensions.PossibleAdInjection2"; | 43 "Extensions.PossibleAdInjection2"; |
| 43 | 44 |
| (...skipping 167 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 211 } | 212 } |
| 212 | 213 |
| 213 scoped_ptr<ExtensionActivity> Action::ConvertToExtensionActivity() { | 214 scoped_ptr<ExtensionActivity> Action::ConvertToExtensionActivity() { |
| 214 scoped_ptr<ExtensionActivity> result(new ExtensionActivity); | 215 scoped_ptr<ExtensionActivity> result(new ExtensionActivity); |
| 215 | 216 |
| 216 // We do this translation instead of using the same enum because the database | 217 // We do this translation instead of using the same enum because the database |
| 217 // values need to be stable; this allows us to change the extension API | 218 // values need to be stable; this allows us to change the extension API |
| 218 // without affecting the database. | 219 // without affecting the database. |
| 219 switch (action_type()) { | 220 switch (action_type()) { |
| 220 case ACTION_API_CALL: | 221 case ACTION_API_CALL: |
| 221 result->activity_type = ExtensionActivity::ACTIVITY_TYPE_API_CALL; | 222 result->activity_type = activity_log::EXTENSION_ACTIVITY_TYPE_API_CALL; |
| 222 break; | 223 break; |
| 223 case ACTION_API_EVENT: | 224 case ACTION_API_EVENT: |
| 224 result->activity_type = ExtensionActivity::ACTIVITY_TYPE_API_EVENT; | 225 result->activity_type = activity_log::EXTENSION_ACTIVITY_TYPE_API_EVENT; |
| 225 break; | 226 break; |
| 226 case ACTION_CONTENT_SCRIPT: | 227 case ACTION_CONTENT_SCRIPT: |
| 227 result->activity_type = ExtensionActivity::ACTIVITY_TYPE_CONTENT_SCRIPT; | 228 result->activity_type = |
| 229 activity_log::EXTENSION_ACTIVITY_TYPE_CONTENT_SCRIPT; |
| 228 break; | 230 break; |
| 229 case ACTION_DOM_ACCESS: | 231 case ACTION_DOM_ACCESS: |
| 230 result->activity_type = ExtensionActivity::ACTIVITY_TYPE_DOM_ACCESS; | 232 result->activity_type = activity_log::EXTENSION_ACTIVITY_TYPE_DOM_ACCESS; |
| 231 break; | 233 break; |
| 232 case ACTION_DOM_EVENT: | 234 case ACTION_DOM_EVENT: |
| 233 result->activity_type = ExtensionActivity::ACTIVITY_TYPE_DOM_EVENT; | 235 result->activity_type = activity_log::EXTENSION_ACTIVITY_TYPE_DOM_EVENT; |
| 234 break; | 236 break; |
| 235 case ACTION_WEB_REQUEST: | 237 case ACTION_WEB_REQUEST: |
| 236 result->activity_type = ExtensionActivity::ACTIVITY_TYPE_WEB_REQUEST; | 238 result->activity_type = activity_log::EXTENSION_ACTIVITY_TYPE_WEB_REQUEST; |
| 237 break; | 239 break; |
| 238 case UNUSED_ACTION_API_BLOCKED: | 240 case UNUSED_ACTION_API_BLOCKED: |
| 239 case ACTION_ANY: | 241 case ACTION_ANY: |
| 240 default: | 242 default: |
| 241 // This shouldn't be reached, but some people might have old or otherwise | 243 // This shouldn't be reached, but some people might have old or otherwise |
| 242 // weird db entries. Treat it like an API call if that happens. | 244 // weird db entries. Treat it like an API call if that happens. |
| 243 result->activity_type = ExtensionActivity::ACTIVITY_TYPE_API_CALL; | 245 result->activity_type = activity_log::EXTENSION_ACTIVITY_TYPE_API_CALL; |
| 244 break; | 246 break; |
| 245 } | 247 } |
| 246 | 248 |
| 247 result->extension_id.reset(new std::string(extension_id())); | 249 result->extension_id.reset(new std::string(extension_id())); |
| 248 result->time.reset(new double(time().ToJsTime())); | 250 result->time.reset(new double(time().ToJsTime())); |
| 249 result->count.reset(new double(count())); | 251 result->count.reset(new double(count())); |
| 250 result->api_call.reset(new std::string(api_name())); | 252 result->api_call.reset(new std::string(api_name())); |
| 251 result->args.reset(new std::string(Serialize(args()))); | 253 result->args.reset(new std::string(Serialize(args()))); |
| 252 if (action_id() != -1) | 254 if (action_id() != -1) |
| 253 result->activity_id.reset( | 255 result->activity_id.reset( |
| (...skipping 21 matching lines...) Expand all Loading... |
| 275 ActivityLogPolicy::Util::Serialize(web_request))); | 277 ActivityLogPolicy::Util::Serialize(web_request))); |
| 276 } | 278 } |
| 277 std::string extra; | 279 std::string extra; |
| 278 if (other()->GetStringWithoutPathExpansion(constants::kActionExtra, &extra)) | 280 if (other()->GetStringWithoutPathExpansion(constants::kActionExtra, &extra)) |
| 279 other_field->extra.reset(new std::string(extra)); | 281 other_field->extra.reset(new std::string(extra)); |
| 280 int dom_verb; | 282 int dom_verb; |
| 281 if (other()->GetIntegerWithoutPathExpansion(constants::kActionDomVerb, | 283 if (other()->GetIntegerWithoutPathExpansion(constants::kActionDomVerb, |
| 282 &dom_verb)) { | 284 &dom_verb)) { |
| 283 switch (static_cast<DomActionType::Type>(dom_verb)) { | 285 switch (static_cast<DomActionType::Type>(dom_verb)) { |
| 284 case DomActionType::GETTER: | 286 case DomActionType::GETTER: |
| 285 other_field->dom_verb = ExtensionActivity::Other::DOM_VERB_GETTER; | 287 other_field->dom_verb = |
| 288 activity_log::EXTENSION_ACTIVITY_DOM_VERB_GETTER; |
| 286 break; | 289 break; |
| 287 case DomActionType::SETTER: | 290 case DomActionType::SETTER: |
| 288 other_field->dom_verb = ExtensionActivity::Other::DOM_VERB_SETTER; | 291 other_field->dom_verb = |
| 292 activity_log::EXTENSION_ACTIVITY_DOM_VERB_SETTER; |
| 289 break; | 293 break; |
| 290 case DomActionType::METHOD: | 294 case DomActionType::METHOD: |
| 291 other_field->dom_verb = ExtensionActivity::Other::DOM_VERB_METHOD; | 295 other_field->dom_verb = |
| 296 activity_log::EXTENSION_ACTIVITY_DOM_VERB_METHOD; |
| 292 break; | 297 break; |
| 293 case DomActionType::INSERTED: | 298 case DomActionType::INSERTED: |
| 294 other_field->dom_verb = ExtensionActivity::Other::DOM_VERB_INSERTED; | 299 other_field->dom_verb = |
| 300 activity_log::EXTENSION_ACTIVITY_DOM_VERB_INSERTED; |
| 295 break; | 301 break; |
| 296 case DomActionType::XHR: | 302 case DomActionType::XHR: |
| 297 other_field->dom_verb = ExtensionActivity::Other::DOM_VERB_XHR; | 303 other_field->dom_verb = activity_log::EXTENSION_ACTIVITY_DOM_VERB_XHR; |
| 298 break; | 304 break; |
| 299 case DomActionType::WEBREQUEST: | 305 case DomActionType::WEBREQUEST: |
| 300 other_field->dom_verb = ExtensionActivity::Other::DOM_VERB_WEBREQUEST; | 306 other_field->dom_verb = |
| 307 activity_log::EXTENSION_ACTIVITY_DOM_VERB_WEBREQUEST; |
| 301 break; | 308 break; |
| 302 case DomActionType::MODIFIED: | 309 case DomActionType::MODIFIED: |
| 303 other_field->dom_verb = ExtensionActivity::Other::DOM_VERB_MODIFIED; | 310 other_field->dom_verb = |
| 311 activity_log::EXTENSION_ACTIVITY_DOM_VERB_MODIFIED; |
| 304 break; | 312 break; |
| 305 default: | 313 default: |
| 306 other_field->dom_verb = ExtensionActivity::Other::DOM_VERB_NONE; | 314 other_field->dom_verb = |
| 315 activity_log::EXTENSION_ACTIVITY_DOM_VERB_NONE; |
| 307 } | 316 } |
| 308 } else { | 317 } else { |
| 309 other_field->dom_verb = ExtensionActivity::Other::DOM_VERB_NONE; | 318 other_field->dom_verb = activity_log::EXTENSION_ACTIVITY_DOM_VERB_NONE; |
| 310 } | 319 } |
| 311 result->other.reset(other_field.release()); | 320 result->other.reset(other_field.release()); |
| 312 } | 321 } |
| 313 | 322 |
| 314 return result.Pass(); | 323 return result.Pass(); |
| 315 } | 324 } |
| 316 | 325 |
| 317 std::string Action::PrintForDebug() const { | 326 std::string Action::PrintForDebug() const { |
| 318 std::string result = base::StringPrintf("ACTION ID=%" PRId64, action_id()); | 327 std::string result = base::StringPrintf("ACTION ID=%" PRId64, action_id()); |
| 319 result += " EXTENSION ID=" + extension_id() + " CATEGORY="; | 328 result += " EXTENSION ID=" + extension_id() + " CATEGORY="; |
| (...skipping 225 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 545 std::string rhs_other = ActivityLogPolicy::Util::Serialize(rhs->other()); | 554 std::string rhs_other = ActivityLogPolicy::Util::Serialize(rhs->other()); |
| 546 if (lhs_other != rhs_other) | 555 if (lhs_other != rhs_other) |
| 547 return lhs_other < rhs_other; | 556 return lhs_other < rhs_other; |
| 548 } | 557 } |
| 549 | 558 |
| 550 // All fields compare as equal if this point is reached. | 559 // All fields compare as equal if this point is reached. |
| 551 return false; | 560 return false; |
| 552 } | 561 } |
| 553 | 562 |
| 554 } // namespace extensions | 563 } // namespace extensions |
| OLD | NEW |