| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 "services/file/file_service.h" | 5 #include "services/file/file_service.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/memory/ptr_util.h" | 8 #include "base/memory/ptr_util.h" |
| 9 #include "base/memory/weak_ptr.h" | 9 #include "base/memory/weak_ptr.h" |
| 10 #include "components/filesystem/lock_table.h" | 10 #include "components/filesystem/lock_table.h" |
| (...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 81 scoped_refptr<base::SingleThreadTaskRunner> file_service_runner, | 81 scoped_refptr<base::SingleThreadTaskRunner> file_service_runner, |
| 82 scoped_refptr<base::SingleThreadTaskRunner> leveldb_service_runner) | 82 scoped_refptr<base::SingleThreadTaskRunner> leveldb_service_runner) |
| 83 : file_service_runner_(std::move(file_service_runner)), | 83 : file_service_runner_(std::move(file_service_runner)), |
| 84 leveldb_service_runner_(std::move(leveldb_service_runner)) {} | 84 leveldb_service_runner_(std::move(leveldb_service_runner)) {} |
| 85 | 85 |
| 86 FileService::~FileService() { | 86 FileService::~FileService() { |
| 87 file_service_runner_->DeleteSoon(FROM_HERE, file_system_objects_.release()); | 87 file_service_runner_->DeleteSoon(FROM_HERE, file_system_objects_.release()); |
| 88 leveldb_service_runner_->DeleteSoon(FROM_HERE, leveldb_objects_.release()); | 88 leveldb_service_runner_->DeleteSoon(FROM_HERE, leveldb_objects_.release()); |
| 89 } | 89 } |
| 90 | 90 |
| 91 void FileService::OnStart(const service_manager::Identity& identity) { | 91 void FileService::OnStart(const service_manager::ServiceInfo& info) { |
| 92 file_system_objects_.reset(new FileService::FileSystemObjects( | 92 file_system_objects_.reset(new FileService::FileSystemObjects( |
| 93 GetUserDirForUserId(identity.user_id()))); | 93 GetUserDirForUserId(info.identity.user_id()))); |
| 94 leveldb_objects_.reset( | 94 leveldb_objects_.reset( |
| 95 new FileService::LevelDBServiceObjects(leveldb_service_runner_)); | 95 new FileService::LevelDBServiceObjects(leveldb_service_runner_)); |
| 96 } | 96 } |
| 97 | 97 |
| 98 bool FileService::OnConnect(const service_manager::Identity& remote_identity, | 98 bool FileService::OnConnect(const service_manager::ServiceInfo& remote_info, |
| 99 service_manager::InterfaceRegistry* registry) { | 99 service_manager::InterfaceRegistry* registry) { |
| 100 registry->AddInterface<leveldb::mojom::LevelDBService>(this); | 100 registry->AddInterface<leveldb::mojom::LevelDBService>(this); |
| 101 registry->AddInterface<mojom::FileSystem>(this); | 101 registry->AddInterface<mojom::FileSystem>(this); |
| 102 return true; | 102 return true; |
| 103 } | 103 } |
| 104 | 104 |
| 105 void FileService::Create(const service_manager::Identity& remote_identity, | 105 void FileService::Create(const service_manager::Identity& remote_identity, |
| 106 mojom::FileSystemRequest request) { | 106 mojom::FileSystemRequest request) { |
| 107 file_service_runner_->PostTask( | 107 file_service_runner_->PostTask( |
| 108 FROM_HERE, | 108 FROM_HERE, |
| 109 base::Bind(&FileService::FileSystemObjects::OnFileSystemRequest, | 109 base::Bind(&FileService::FileSystemObjects::OnFileSystemRequest, |
| 110 file_system_objects_->AsWeakPtr(), remote_identity, | 110 file_system_objects_->AsWeakPtr(), remote_identity, |
| 111 base::Passed(&request))); | 111 base::Passed(&request))); |
| 112 } | 112 } |
| 113 | 113 |
| 114 void FileService::Create(const service_manager::Identity& remote_identity, | 114 void FileService::Create(const service_manager::Identity& remote_identity, |
| 115 leveldb::mojom::LevelDBServiceRequest request) { | 115 leveldb::mojom::LevelDBServiceRequest request) { |
| 116 leveldb_service_runner_->PostTask( | 116 leveldb_service_runner_->PostTask( |
| 117 FROM_HERE, | 117 FROM_HERE, |
| 118 base::Bind( | 118 base::Bind( |
| 119 &FileService::LevelDBServiceObjects::OnLevelDBServiceRequest, | 119 &FileService::LevelDBServiceObjects::OnLevelDBServiceRequest, |
| 120 leveldb_objects_->AsWeakPtr(), remote_identity, | 120 leveldb_objects_->AsWeakPtr(), remote_identity, |
| 121 base::Passed(&request))); | 121 base::Passed(&request))); |
| 122 } | 122 } |
| 123 | 123 |
| 124 } // namespace user_service | 124 } // namespace user_service |
| OLD | NEW |