| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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_log.h" | 5 #include "chrome/browser/extensions/activity_log/activity_log.h" |
| 6 | 6 |
| 7 #include <set> | 7 #include <set> |
| 8 #include <vector> | 8 #include <vector> |
| 9 | 9 |
| 10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
| 11 #include "base/json/json_string_value_serializer.h" | 11 #include "base/json/json_string_value_serializer.h" |
| 12 #include "base/logging.h" | 12 #include "base/logging.h" |
| 13 #include "base/strings/string_util.h" | 13 #include "base/strings/string_util.h" |
| 14 #include "base/strings/utf_string_conversions.h" | 14 #include "base/strings/utf_string_conversions.h" |
| 15 #include "base/threading/thread_checker.h" | 15 #include "base/threading/thread_checker.h" |
| 16 #include "chrome/browser/extensions/activity_log/activity_action_constants.h" | 16 #include "chrome/browser/extensions/activity_log/activity_action_constants.h" |
| 17 #include "chrome/browser/extensions/activity_log/counting_policy.h" | 17 #include "chrome/browser/extensions/activity_log/counting_policy.h" |
| 18 #include "chrome/browser/extensions/activity_log/fullstream_ui_policy.h" | 18 #include "chrome/browser/extensions/activity_log/fullstream_ui_policy.h" |
| 19 #include "chrome/browser/extensions/api/activity_log_private/activity_log_privat
e_api.h" | 19 #include "chrome/browser/extensions/api/activity_log_private/activity_log_privat
e_api.h" |
| 20 #include "chrome/browser/extensions/extension_service.h" | 20 #include "chrome/browser/extensions/extension_service.h" |
| 21 #include "chrome/browser/extensions/extension_system_factory.h" | 21 #include "chrome/browser/extensions/extension_system_factory.h" |
| 22 #include "chrome/browser/extensions/extension_tab_util.h" | 22 #include "chrome/browser/extensions/extension_tab_util.h" |
| 23 #include "chrome/browser/extensions/install_tracker.h" |
| 23 #include "chrome/browser/extensions/install_tracker_factory.h" | 24 #include "chrome/browser/extensions/install_tracker_factory.h" |
| 24 #include "chrome/browser/prefs/pref_service_syncable.h" | 25 #include "chrome/browser/prefs/pref_service_syncable.h" |
| 25 #include "chrome/browser/prerender/prerender_manager.h" | 26 #include "chrome/browser/prerender/prerender_manager.h" |
| 26 #include "chrome/browser/prerender/prerender_manager_factory.h" | 27 #include "chrome/browser/prerender/prerender_manager_factory.h" |
| 27 #include "chrome/browser/profiles/incognito_helpers.h" | 28 #include "chrome/browser/profiles/incognito_helpers.h" |
| 29 #include "chrome/browser/profiles/profile.h" |
| 28 #include "chrome/browser/ui/browser.h" | 30 #include "chrome/browser/ui/browser.h" |
| 29 #include "chrome/common/chrome_constants.h" | 31 #include "chrome/common/chrome_constants.h" |
| 30 #include "chrome/common/chrome_switches.h" | 32 #include "chrome/common/chrome_switches.h" |
| 31 #include "chrome/common/pref_names.h" | 33 #include "chrome/common/pref_names.h" |
| 32 #include "components/browser_context_keyed_service/browser_context_dependency_ma
nager.h" | 34 #include "components/browser_context_keyed_service/browser_context_dependency_ma
nager.h" |
| 35 #include "content/public/browser/browser_thread.h" |
| 33 #include "content/public/browser/web_contents.h" | 36 #include "content/public/browser/web_contents.h" |
| 34 #include "extensions/browser/extension_system.h" | 37 #include "extensions/browser/extension_system.h" |
| 38 #include "extensions/browser/extensions_browser_client.h" |
| 35 #include "extensions/common/extension.h" | 39 #include "extensions/common/extension.h" |
| 36 #include "third_party/re2/re2/re2.h" | 40 #include "third_party/re2/re2/re2.h" |
| 37 #include "url/gurl.h" | 41 #include "url/gurl.h" |
| 38 | 42 |
| 39 #if !defined(OS_ANDROID) | 43 #if !defined(OS_ANDROID) |
| 40 #include "chrome/browser/extensions/activity_log/uma_policy.h" | 44 #include "chrome/browser/extensions/activity_log/uma_policy.h" |
| 41 #endif | 45 #endif |
| 42 | 46 |
| 43 namespace constants = activity_log_constants; | 47 namespace constants = activity_log_constants; |
| 44 | 48 |
| 45 namespace { | 49 namespace { |
| 46 | 50 |
| 47 using extensions::Action; | 51 using extensions::Action; |
| 48 using constants::kArgUrlPlaceholder; | 52 using constants::kArgUrlPlaceholder; |
| 53 using content::BrowserThread; |
| 49 | 54 |
| 50 // If DOM API methods start with this string, we flag them as being of type | 55 // If DOM API methods start with this string, we flag them as being of type |
| 51 // DomActionType::XHR. | 56 // DomActionType::XHR. |
| 52 const char kDomXhrPrefix[] = "XMLHttpRequest."; | 57 const char kDomXhrPrefix[] = "XMLHttpRequest."; |
| 53 | 58 |
| 54 // Specifies a possible action to take to get an extracted URL in the ApiInfo | 59 // Specifies a possible action to take to get an extracted URL in the ApiInfo |
| 55 // structure below. | 60 // structure below. |
| 56 enum Transformation { | 61 enum Transformation { |
| 57 NONE, | 62 NONE, |
| 58 DICT_LOOKUP, | 63 DICT_LOOKUP, |
| (...skipping 327 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 386 | 391 |
| 387 db_enabled_ = has_threads_ | 392 db_enabled_ = has_threads_ |
| 388 && (CommandLine::ForCurrentProcess()-> | 393 && (CommandLine::ForCurrentProcess()-> |
| 389 HasSwitch(switches::kEnableExtensionActivityLogging) | 394 HasSwitch(switches::kEnableExtensionActivityLogging) |
| 390 || watchdog_apps_active_); | 395 || watchdog_apps_active_); |
| 391 | 396 |
| 392 ExtensionSystem::Get(profile_)->ready().Post( | 397 ExtensionSystem::Get(profile_)->ready().Post( |
| 393 FROM_HERE, | 398 FROM_HERE, |
| 394 base::Bind(&ActivityLog::InitInstallTracker, base::Unretained(this))); | 399 base::Bind(&ActivityLog::InitInstallTracker, base::Unretained(this))); |
| 395 | 400 |
| 396 EventRouter* event_router = ExtensionSystem::Get(profile_)->event_router(); | |
| 397 if (event_router) | |
| 398 event_router->SetEventDispatchObserver(this); | |
| 399 | |
| 400 // None of this should run on Android since the AL is behind ENABLE_EXTENSION | 401 // None of this should run on Android since the AL is behind ENABLE_EXTENSION |
| 401 // checks. However, UmaPolicy can't even compile on Android because it uses | 402 // checks. However, UmaPolicy can't even compile on Android because it uses |
| 402 // BrowserList and related classes that aren't compiled for Android. | 403 // BrowserList and related classes that aren't compiled for Android. |
| 403 #if !defined(OS_ANDROID) | 404 #if !defined(OS_ANDROID) |
| 404 if (!profile->IsOffTheRecord()) | 405 if (!profile->IsOffTheRecord()) |
| 405 uma_policy_ = new UmaPolicy(profile_); | 406 uma_policy_ = new UmaPolicy(profile_); |
| 406 #endif | 407 #endif |
| 407 | 408 |
| 408 ChooseDatabasePolicy(); | 409 ChooseDatabasePolicy(); |
| 409 } | 410 } |
| (...skipping 200 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 610 for (std::set<std::string>::const_iterator it2 = it->second.begin(); | 611 for (std::set<std::string>::const_iterator it2 = it->second.begin(); |
| 611 it2 != it->second.end(); | 612 it2 != it->second.end(); |
| 612 ++it2) { | 613 ++it2) { |
| 613 action->mutable_args()->AppendString(*it2); | 614 action->mutable_args()->AppendString(*it2); |
| 614 } | 615 } |
| 615 LogAction(action); | 616 LogAction(action); |
| 616 } | 617 } |
| 617 } | 618 } |
| 618 } | 619 } |
| 619 | 620 |
| 620 void ActivityLog::OnWillDispatchEvent(scoped_ptr<EventDispatchInfo> details) { | 621 void ActivityLog::OnApiEventDispatched(const std::string& extension_id, |
| 621 scoped_refptr<Action> action = new Action(details->extension_id, | 622 const std::string& event_name, |
| 623 scoped_ptr<base::ListValue> event_args) { |
| 624 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 625 scoped_refptr<Action> action = new Action(extension_id, |
| 622 base::Time::Now(), | 626 base::Time::Now(), |
| 623 Action::ACTION_API_EVENT, | 627 Action::ACTION_API_EVENT, |
| 624 details->event_name); | 628 event_name); |
| 625 action->set_args(details->event_args.Pass()); | 629 action->set_args(event_args.Pass()); |
| 626 LogAction(action); | 630 LogAction(action); |
| 627 } | 631 } |
| 628 | 632 |
| 633 void ActivityLog::OnApiFunctionCalled(const std::string& extension_id, |
| 634 const std::string& api_name, |
| 635 scoped_ptr<base::ListValue> args) { |
| 636 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 637 scoped_refptr<Action> action = new Action(extension_id, |
| 638 base::Time::Now(), |
| 639 Action::ACTION_API_CALL, |
| 640 api_name); |
| 641 action->set_args(args.Pass()); |
| 642 LogAction(action); |
| 643 } |
| 644 |
| 629 // LOOKUP ACTIONS. ------------------------------------------------------------- | 645 // LOOKUP ACTIONS. ------------------------------------------------------------- |
| 630 | 646 |
| 631 void ActivityLog::GetFilteredActions( | 647 void ActivityLog::GetFilteredActions( |
| 632 const std::string& extension_id, | 648 const std::string& extension_id, |
| 633 const Action::ActionType type, | 649 const Action::ActionType type, |
| 634 const std::string& api_name, | 650 const std::string& api_name, |
| 635 const std::string& page_url, | 651 const std::string& page_url, |
| 636 const std::string& arg_url, | 652 const std::string& arg_url, |
| 637 const int daysAgo, | 653 const int daysAgo, |
| 638 const base::Callback | 654 const base::Callback |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 671 RemoveURLs(urls); | 687 RemoveURLs(urls); |
| 672 } | 688 } |
| 673 | 689 |
| 674 void ActivityLog::DeleteDatabase() { | 690 void ActivityLog::DeleteDatabase() { |
| 675 if (!database_policy_) | 691 if (!database_policy_) |
| 676 return; | 692 return; |
| 677 database_policy_->DeleteDatabase(); | 693 database_policy_->DeleteDatabase(); |
| 678 } | 694 } |
| 679 | 695 |
| 680 } // namespace extensions | 696 } // namespace extensions |
| OLD | NEW |