Index: components/safe_browsing_db/v4_local_database_manager.cc |
diff --git a/components/safe_browsing_db/v4_local_database_manager.cc b/components/safe_browsing_db/v4_local_database_manager.cc |
index 30812a01b3cf971d084c877d23d70708e5b844d3..71089dcf83bf252778c8e6a4f67150ea894a631a 100644 |
--- a/components/safe_browsing_db/v4_local_database_manager.cc |
+++ b/components/safe_browsing_db/v4_local_database_manager.cc |
@@ -152,27 +152,11 @@ void V4LocalDatabaseManager::StartOnIOThread( |
void V4LocalDatabaseManager::SetupUpdateProtocolManager( |
net::URLRequestContextGetter* request_context_getter, |
const V4ProtocolConfig& config) { |
-#if defined(OS_WIN) || defined(OS_LINUX) || defined(OS_MACOSX) |
- // TODO(vakh): Remove this if/endif block when the V4Database is implemented. |
- // Filed as http://crbug.com/608075 |
- UpdateListIdentifier update_list_identifier; |
-#if defined(OS_WIN) |
- update_list_identifier.platform_type = WINDOWS_PLATFORM; |
-#elif defined(OS_LINUX) |
- update_list_identifier.platform_type = LINUX_PLATFORM; |
-#else |
- update_list_identifier.platform_type = OSX_PLATFORM; |
-#endif |
- update_list_identifier.threat_entry_type = URL; |
- update_list_identifier.threat_type = MALWARE_THREAT; |
- current_list_states_[update_list_identifier] = ""; |
-#endif |
- |
V4UpdateCallback callback = base::Bind( |
&V4LocalDatabaseManager::UpdateRequestCompleted, base::Unretained(this)); |
- v4_update_protocol_manager_ = V4UpdateProtocolManager::Create( |
- request_context_getter, config, current_list_states_, callback); |
+ v4_update_protocol_manager_ = |
+ V4UpdateProtocolManager::Create(request_context_getter, config, callback); |
} |
void V4LocalDatabaseManager::SetupDatabase() { |
@@ -187,16 +171,40 @@ void V4LocalDatabaseManager::SetupDatabase() { |
pool->GetSequenceToken(), base::SequencedWorkerPool::SKIP_ON_SHUTDOWN); |
} |
- // TODO(vakh): list_info_map should probably be a hard-coded map. |
- ListInfoMap list_info_map; |
+ StoreFileNameMap store_file_name_map; |
+ PopulateStoreFileNameMap(&store_file_name_map); |
Scott Hess - ex-Googler
2016/06/17 22:53:43
Could PopulateStoreFileNameMap() just return a map
vakh (use Gerrit instead)
2016/06/20 22:28:42
Done.
|
// Do not create the database on the IO thread since this may be an expensive |
// operation. Instead, do that on the task_runner and when the new database |
// has been created, swap it out on the IO thread. |
+ DCHECK(!store_file_name_map.empty()); |
+ DatabaseUpdatedCallback db_updated_callback = base::Bind( |
+ &V4LocalDatabaseManager::DatabaseUpdated, base::Unretained(this)); |
NewDatabaseReadyCallback db_ready_callback = base::Bind( |
&V4LocalDatabaseManager::DatabaseReady, base::Unretained(this)); |
- V4Database::Create(task_runner_, base_path_, list_info_map, |
- db_ready_callback); |
+ V4Database::Create(task_runner_, base_path_, store_file_name_map, |
+ db_updated_callback, db_ready_callback); |
+} |
+ |
+void V4LocalDatabaseManager::PopulateStoreFileNameMap( |
+ StoreFileNameMap* store_file_name_map) { |
+// TODO(vakh): Implement this to populate the map appopriately. |
+// Filed as http://crbug.com/608075 |
+#if defined(OS_WIN) |
+ PlatformType platform_type = WINDOWS_PLATFORM; |
+#elif defined(OS_LINUX) |
+ PlatformType platform_type = LINUX_PLATFORM; |
+#else |
Scott Hess - ex-Googler
2016/06/17 22:53:43
I think there should be no default,
#elif defined(
vakh (use Gerrit instead)
2016/06/20 22:28:42
This code is getting compiled on Android for an un
Scott Hess - ex-Googler
2016/06/21 21:03:44
Suggest having an explicit case for OS_OSX, plus a
vakh (use Gerrit instead)
2016/06/21 23:19:35
Done.
|
+ PlatformType platform_type = OSX_PLATFORM; |
+#endif |
+ // This is designed to fail compilation for other platforms because |
+ // |platform_type| won't be declared. |
Scott Hess - ex-Googler
2016/06/17 22:53:43
I vote for no comment. I think anyone debugging w
vakh (use Gerrit instead)
2016/06/20 22:28:42
Done.
|
+ UpdateListIdentifier update_list_identifier(platform_type, URL, |
+ MALWARE_THREAT); |
+ (*store_file_name_map)[update_list_identifier] = "os_url_malware.store"; |
+ |
+ update_list_identifier.threat_type = SOCIAL_ENGINEERING_PUBLIC; |
Scott Hess - ex-Googler
2016/06/17 22:53:43
I am not entirely comfortable with this, because i
vakh (use Gerrit instead)
2016/06/20 22:28:42
Done.
|
+ (*store_file_name_map)[update_list_identifier] = "os_url_soceng.store"; |
} |
void V4LocalDatabaseManager::DatabaseReady( |
@@ -208,6 +216,9 @@ void V4LocalDatabaseManager::DatabaseReady( |
if (enabled_) { |
v4_database_ = std::move(v4_database); |
+ v4_update_protocol_manager_->SetStoreStateMap( |
+ v4_database_->store_state_map()); |
+ |
// The database is in place. Start fetching updates now. |
v4_update_protocol_manager_->ScheduleNextUpdate(); |
} else { |
@@ -236,8 +247,10 @@ void V4LocalDatabaseManager::StopOnIOThread(bool shutdown) { |
void V4LocalDatabaseManager::UpdateRequestCompleted( |
const std::vector<ListUpdateResponse>& responses) { |
DCHECK_CURRENTLY_ON(BrowserThread::IO); |
+ v4_database_->ApplyUpdate(responses); |
Scott Hess - ex-Googler
2016/06/17 22:53:43
WRT my comment elsewhere with many store tasks ver
vakh (use Gerrit instead)
2016/06/20 22:28:43
Still not sure about updating all stores at once,
Scott Hess - ex-Googler
2016/06/21 21:03:44
It's more efficient, probably. But a call like th
vakh (use Gerrit instead)
2016/06/21 23:19:35
The other callbacks in this class also work the sa
Scott Hess - ex-Googler
2016/06/24 23:01:19
AFAICT there's only that one callback which is sto
vakh (use Gerrit instead)
2016/06/27 19:38:26
Your reading is right. What I wrote is different t
Scott Hess - ex-Googler
2016/06/27 22:19:17
OK, I guess I'll leave this to you. I find the st
vakh (use Gerrit instead)
2016/06/27 23:58:52
Done.
|
+} |
- // TODO(vakh): Updates downloaded. Store them on disk and record new state. |
+void V4LocalDatabaseManager::DatabaseUpdated() { |
v4_update_protocol_manager_->ScheduleNextUpdate(); |
} |