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" |
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
50 arraysize(FullStreamUIPolicy::kTableContentFields); | 50 arraysize(FullStreamUIPolicy::kTableContentFields); |
51 | 51 |
52 FullStreamUIPolicy::FullStreamUIPolicy(Profile* profile) | 52 FullStreamUIPolicy::FullStreamUIPolicy(Profile* profile) |
53 : ActivityLogDatabasePolicy( | 53 : ActivityLogDatabasePolicy( |
54 profile, | 54 profile, |
55 FilePath(chrome::kExtensionActivityLogFilename)) {} | 55 FilePath(chrome::kExtensionActivityLogFilename)) {} |
56 | 56 |
57 FullStreamUIPolicy::~FullStreamUIPolicy() {} | 57 FullStreamUIPolicy::~FullStreamUIPolicy() {} |
58 | 58 |
59 bool FullStreamUIPolicy::InitDatabase(sql::Connection* db) { | 59 bool FullStreamUIPolicy::InitDatabase(sql::Connection* db) { |
60 if (!Util::DropObsoleteTables(db)) | |
61 return false; | |
62 | |
63 // Create the unified activity log entry table. | 60 // Create the unified activity log entry table. |
64 return ActivityDatabase::InitializeTable(db, | 61 return ActivityDatabase::InitializeTable(db, |
65 kTableName, | 62 kTableName, |
66 kTableContentFields, | 63 kTableContentFields, |
67 kTableFieldTypes, | 64 kTableFieldTypes, |
68 arraysize(kTableContentFields)); | 65 arraysize(kTableContentFields)); |
69 } | 66 } |
70 | 67 |
71 bool FullStreamUIPolicy::FlushDatabase(sql::Connection* db) { | 68 bool FullStreamUIPolicy::FlushDatabase(sql::Connection* db) { |
72 if (queued_actions_.empty()) | 69 if (queued_actions_.empty()) |
73 return true; | 70 return true; |
74 | 71 |
75 sql::Transaction transaction(db); | 72 sql::Transaction transaction(db); |
76 if (!transaction.Begin()) | 73 if (!transaction.Begin()) |
77 return false; | 74 return false; |
78 | 75 |
79 std::string sql_str = | 76 std::string sql_str = |
80 "INSERT INTO " + std::string(FullStreamUIPolicy::kTableName) + | 77 "INSERT INTO " + std::string(FullStreamUIPolicy::kTableName) + |
81 " (extension_id, time, action_type, api_name, args, " | 78 " (extension_id, time, action_type, api_name, args, " |
82 "page_url, page_title, arg_url, other) VALUES (?,?,?,?,?,?,?,?,?)"; | 79 "page_url, page_title, arg_url, other) VALUES (?,?,?,?,?,?,?,?,?)"; |
83 sql::Statement statement(db->GetCachedStatement( | 80 sql::Statement statement(db->GetCachedStatement( |
84 sql::StatementID(SQL_FROM_HERE), sql_str.c_str())); | 81 sql::StatementID(SQL_FROM_HERE), sql_str.c_str())); |
85 | 82 |
86 Action::ActionVector::size_type i; | 83 for (size_t i = 0; i != queued_actions_.size(); ++i) { |
87 for (i = 0; i != queued_actions_.size(); ++i) { | |
88 const Action& action = *queued_actions_[i]; | 84 const Action& action = *queued_actions_[i]; |
89 statement.Reset(true); | 85 statement.Reset(true); |
90 statement.BindString(0, action.extension_id()); | 86 statement.BindString(0, action.extension_id()); |
91 statement.BindInt64(1, action.time().ToInternalValue()); | 87 statement.BindInt64(1, action.time().ToInternalValue()); |
92 statement.BindInt(2, static_cast<int>(action.action_type())); | 88 statement.BindInt(2, static_cast<int>(action.action_type())); |
93 statement.BindString(3, action.api_name()); | 89 statement.BindString(3, action.api_name()); |
94 if (action.args()) { | 90 if (action.args()) { |
95 statement.BindString(4, Util::Serialize(action.args())); | 91 statement.BindString(4, Util::Serialize(action.args())); |
96 } | 92 } |
97 std::string page_url_string = action.SerializePageUrl(); | 93 std::string page_url_string = action.SerializePageUrl(); |
(...skipping 349 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
447 } | 443 } |
448 | 444 |
449 void FullStreamUIPolicy::QueueAction(scoped_refptr<Action> action) { | 445 void FullStreamUIPolicy::QueueAction(scoped_refptr<Action> action) { |
450 if (activity_database()->is_db_valid()) { | 446 if (activity_database()->is_db_valid()) { |
451 queued_actions_.push_back(action); | 447 queued_actions_.push_back(action); |
452 activity_database()->AdviseFlush(queued_actions_.size()); | 448 activity_database()->AdviseFlush(queued_actions_.size()); |
453 } | 449 } |
454 } | 450 } |
455 | 451 |
456 } // namespace extensions | 452 } // namespace extensions |
OLD | NEW |