OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 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/fullstream_ui_policy.h" | 5 #include "chrome/browser/extensions/activity_log/fullstream_ui_policy.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 | 8 |
9 #include "base/callback.h" | 9 #include "base/callback.h" |
10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
11 #include "base/files/file_path.h" | 11 #include "base/files/file_path.h" |
12 #include "base/json/json_reader.h" | 12 #include "base/json/json_reader.h" |
13 #include "base/json/json_string_value_serializer.h" | 13 #include "base/json/json_string_value_serializer.h" |
14 #include "base/logging.h" | 14 #include "base/logging.h" |
15 #include "base/macros.h" | 15 #include "base/macros.h" |
16 #include "base/memory/ptr_util.h" | 16 #include "base/memory/ptr_util.h" |
17 #include "base/strings/string16.h" | 17 #include "base/strings/string16.h" |
18 #include "base/strings/stringprintf.h" | 18 #include "base/strings/stringprintf.h" |
| 19 #include "base/task_runner_util.h" |
19 #include "chrome/browser/extensions/activity_log/activity_action_constants.h" | 20 #include "chrome/browser/extensions/activity_log/activity_action_constants.h" |
20 #include "chrome/browser/extensions/activity_log/activity_database.h" | 21 #include "chrome/browser/extensions/activity_log/activity_database.h" |
| 22 #include "chrome/browser/extensions/activity_log/activity_log_task_runner.h" |
21 #include "chrome/browser/profiles/profile.h" | 23 #include "chrome/browser/profiles/profile.h" |
22 #include "chrome/common/chrome_constants.h" | 24 #include "chrome/common/chrome_constants.h" |
23 #include "chrome/common/chrome_switches.h" | 25 #include "chrome/common/chrome_switches.h" |
24 #include "extensions/common/dom_action_types.h" | 26 #include "extensions/common/dom_action_types.h" |
25 #include "extensions/common/extension.h" | 27 #include "extensions/common/extension.h" |
26 #include "sql/statement.h" | 28 #include "sql/statement.h" |
27 #include "sql/transaction.h" | 29 #include "sql/transaction.h" |
28 #include "url/gurl.h" | 30 #include "url/gurl.h" |
29 | 31 |
30 using base::Callback; | 32 using base::Callback; |
(...skipping 345 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
376 | 378 |
377 void FullStreamUIPolicy::OnDatabaseFailure() { | 379 void FullStreamUIPolicy::OnDatabaseFailure() { |
378 queued_actions_.clear(); | 380 queued_actions_.clear(); |
379 } | 381 } |
380 | 382 |
381 void FullStreamUIPolicy::OnDatabaseClose() { | 383 void FullStreamUIPolicy::OnDatabaseClose() { |
382 delete this; | 384 delete this; |
383 } | 385 } |
384 | 386 |
385 void FullStreamUIPolicy::Close() { | 387 void FullStreamUIPolicy::Close() { |
386 // The policy object should have never been created if there's no DB thread. | |
387 DCHECK(BrowserThread::IsMessageLoopValid(BrowserThread::DB)); | |
388 ScheduleAndForget(activity_database(), &ActivityDatabase::Close); | 388 ScheduleAndForget(activity_database(), &ActivityDatabase::Close); |
389 } | 389 } |
390 | 390 |
391 void FullStreamUIPolicy::ReadFilteredData( | 391 void FullStreamUIPolicy::ReadFilteredData( |
392 const std::string& extension_id, | 392 const std::string& extension_id, |
393 const Action::ActionType type, | 393 const Action::ActionType type, |
394 const std::string& api_name, | 394 const std::string& api_name, |
395 const std::string& page_url, | 395 const std::string& page_url, |
396 const std::string& arg_url, | 396 const std::string& arg_url, |
397 const int days_ago, | 397 const int days_ago, |
398 const base::Callback<void(std::unique_ptr<Action::ActionVector>)>& | 398 const base::Callback<void(std::unique_ptr<Action::ActionVector>)>& |
399 callback) { | 399 callback) { |
400 BrowserThread::PostTaskAndReplyWithResult( | 400 base::PostTaskAndReplyWithResult( |
401 BrowserThread::DB, | 401 GetActivityLogTaskRunner().get(), FROM_HERE, |
402 FROM_HERE, | |
403 base::Bind(&FullStreamUIPolicy::DoReadFilteredData, | 402 base::Bind(&FullStreamUIPolicy::DoReadFilteredData, |
404 base::Unretained(this), | 403 base::Unretained(this), extension_id, type, api_name, page_url, |
405 extension_id, | 404 arg_url, days_ago), |
406 type, | |
407 api_name, | |
408 page_url, | |
409 arg_url, | |
410 days_ago), | |
411 callback); | 405 callback); |
412 } | 406 } |
413 | 407 |
414 void FullStreamUIPolicy::RemoveActions(const std::vector<int64_t>& action_ids) { | 408 void FullStreamUIPolicy::RemoveActions(const std::vector<int64_t>& action_ids) { |
415 ScheduleAndForget(this, &FullStreamUIPolicy::DoRemoveActions, action_ids); | 409 ScheduleAndForget(this, &FullStreamUIPolicy::DoRemoveActions, action_ids); |
416 } | 410 } |
417 | 411 |
418 void FullStreamUIPolicy::RemoveURLs(const std::vector<GURL>& restrict_urls) { | 412 void FullStreamUIPolicy::RemoveURLs(const std::vector<GURL>& restrict_urls) { |
419 ScheduleAndForget(this, &FullStreamUIPolicy::DoRemoveURLs, restrict_urls); | 413 ScheduleAndForget(this, &FullStreamUIPolicy::DoRemoveURLs, restrict_urls); |
420 } | 414 } |
(...skipping 22 matching lines...) Expand all Loading... |
443 } | 437 } |
444 | 438 |
445 void FullStreamUIPolicy::QueueAction(scoped_refptr<Action> action) { | 439 void FullStreamUIPolicy::QueueAction(scoped_refptr<Action> action) { |
446 if (activity_database()->is_db_valid()) { | 440 if (activity_database()->is_db_valid()) { |
447 queued_actions_.push_back(action); | 441 queued_actions_.push_back(action); |
448 activity_database()->AdviseFlush(queued_actions_.size()); | 442 activity_database()->AdviseFlush(queued_actions_.size()); |
449 } | 443 } |
450 } | 444 } |
451 | 445 |
452 } // namespace extensions | 446 } // namespace extensions |
OLD | NEW |