| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/pepper_flash_settings_manager.h" | 5 #include "chrome/browser/pepper_flash_settings_manager.h" |
| 6 | 6 |
| 7 #include <map> | 7 #include <map> |
| 8 #include <utility> | 8 #include <utility> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| 11 #include "base/bind.h" | 11 #include "base/bind.h" |
| 12 #include "base/compiler_specific.h" | 12 #include "base/compiler_specific.h" |
| 13 #include "base/files/file_util.h" | 13 #include "base/files/file_util.h" |
| 14 #include "base/prefs/pref_service.h" | 14 #include "base/prefs/pref_service.h" |
| 15 #include "base/sequenced_task_runner_helpers.h" | 15 #include "base/sequenced_task_runner_helpers.h" |
| 16 #include "base/strings/utf_string_conversions.h" | 16 #include "base/strings/utf_string_conversions.h" |
| 17 #include "build/build_config.h" |
| 17 #include "chrome/browser/plugins/plugin_prefs.h" | 18 #include "chrome/browser/plugins/plugin_prefs.h" |
| 18 #include "chrome/browser/profiles/profile.h" | 19 #include "chrome/browser/profiles/profile.h" |
| 19 #include "chrome/browser/renderer_host/pepper/device_id_fetcher.h" | 20 #include "chrome/browser/renderer_host/pepper/device_id_fetcher.h" |
| 20 #include "chrome/common/pref_names.h" | 21 #include "chrome/common/pref_names.h" |
| 21 #include "components/pref_registry/pref_registry_syncable.h" | 22 #include "components/pref_registry/pref_registry_syncable.h" |
| 22 #include "content/public/browser/browser_context.h" | 23 #include "content/public/browser/browser_context.h" |
| 23 #include "content/public/browser/browser_thread.h" | 24 #include "content/public/browser/browser_thread.h" |
| 24 #include "content/public/browser/pepper_flash_settings_helper.h" | 25 #include "content/public/browser/pepper_flash_settings_helper.h" |
| 25 #include "content/public/browser/plugin_service.h" | 26 #include "content/public/browser/plugin_service.h" |
| 26 #include "content/public/common/content_constants.h" | 27 #include "content/public/common/content_constants.h" |
| (...skipping 11 matching lines...) Expand all Loading... |
| 38 public: | 39 public: |
| 39 Core(base::WeakPtr<PepperFlashSettingsManager> manager, | 40 Core(base::WeakPtr<PepperFlashSettingsManager> manager, |
| 40 content::BrowserContext* browser_context); | 41 content::BrowserContext* browser_context); |
| 41 | 42 |
| 42 void Initialize(); | 43 void Initialize(); |
| 43 | 44 |
| 44 // Notifies the core that it has been detached. Afterwards, no method should | 45 // Notifies the core that it has been detached. Afterwards, no method should |
| 45 // be called any more. | 46 // be called any more. |
| 46 void Detach(); | 47 void Detach(); |
| 47 | 48 |
| 48 void DeauthorizeContentLicenses(uint32 request_id); | 49 void DeauthorizeContentLicenses(uint32_t request_id); |
| 49 void GetPermissionSettings( | 50 void GetPermissionSettings( |
| 50 uint32 request_id, | 51 uint32_t request_id, |
| 51 PP_Flash_BrowserOperations_SettingType setting_type); | 52 PP_Flash_BrowserOperations_SettingType setting_type); |
| 52 void SetDefaultPermission( | 53 void SetDefaultPermission(uint32_t request_id, |
| 53 uint32 request_id, | 54 PP_Flash_BrowserOperations_SettingType setting_type, |
| 54 PP_Flash_BrowserOperations_SettingType setting_type, | 55 PP_Flash_BrowserOperations_Permission permission, |
| 55 PP_Flash_BrowserOperations_Permission permission, | 56 bool clear_site_specific); |
| 56 bool clear_site_specific); | 57 void SetSitePermission(uint32_t request_id, |
| 57 void SetSitePermission(uint32 request_id, | |
| 58 PP_Flash_BrowserOperations_SettingType setting_type, | 58 PP_Flash_BrowserOperations_SettingType setting_type, |
| 59 const ppapi::FlashSiteSettings& sites); | 59 const ppapi::FlashSiteSettings& sites); |
| 60 void GetSitesWithData(uint32 request_id); | 60 void GetSitesWithData(uint32_t request_id); |
| 61 void ClearSiteData(uint32 request_id, | 61 void ClearSiteData(uint32_t request_id, |
| 62 const std::string& site, | 62 const std::string& site, |
| 63 uint64 flags, | 63 uint64_t flags, |
| 64 uint64 max_age); | 64 uint64_t max_age); |
| 65 | 65 |
| 66 // IPC::Listener implementation. | 66 // IPC::Listener implementation. |
| 67 bool OnMessageReceived(const IPC::Message& message) override; | 67 bool OnMessageReceived(const IPC::Message& message) override; |
| 68 void OnChannelError() override; | 68 void OnChannelError() override; |
| 69 | 69 |
| 70 private: | 70 private: |
| 71 friend struct BrowserThread::DeleteOnThread<BrowserThread::IO>; | 71 friend struct BrowserThread::DeleteOnThread<BrowserThread::IO>; |
| 72 friend class base::DeleteHelper<Core>; | 72 friend class base::DeleteHelper<Core>; |
| 73 | 73 |
| 74 enum RequestType { | 74 enum RequestType { |
| (...skipping 17 matching lines...) Expand all Loading... |
| 92 PendingRequest() | 92 PendingRequest() |
| 93 : id(0), | 93 : id(0), |
| 94 type(INVALID_REQUEST_TYPE), | 94 type(INVALID_REQUEST_TYPE), |
| 95 setting_type(PP_FLASH_BROWSEROPERATIONS_SETTINGTYPE_CAMERAMIC), | 95 setting_type(PP_FLASH_BROWSEROPERATIONS_SETTINGTYPE_CAMERAMIC), |
| 96 permission(PP_FLASH_BROWSEROPERATIONS_PERMISSION_DEFAULT), | 96 permission(PP_FLASH_BROWSEROPERATIONS_PERMISSION_DEFAULT), |
| 97 clear_site_specific(false), | 97 clear_site_specific(false), |
| 98 flags(0), | 98 flags(0), |
| 99 max_age(0) { | 99 max_age(0) { |
| 100 } | 100 } |
| 101 | 101 |
| 102 uint32 id; | 102 uint32_t id; |
| 103 RequestType type; | 103 RequestType type; |
| 104 | 104 |
| 105 // Used by GET_PERMISSION_SETTINGS, SET_DEFAULT_PERMISSION and | 105 // Used by GET_PERMISSION_SETTINGS, SET_DEFAULT_PERMISSION and |
| 106 // SET_SITE_PERMISSION. | 106 // SET_SITE_PERMISSION. |
| 107 PP_Flash_BrowserOperations_SettingType setting_type; | 107 PP_Flash_BrowserOperations_SettingType setting_type; |
| 108 | 108 |
| 109 // Used by SET_DEFAULT_PERMISSION. | 109 // Used by SET_DEFAULT_PERMISSION. |
| 110 PP_Flash_BrowserOperations_Permission permission; | 110 PP_Flash_BrowserOperations_Permission permission; |
| 111 bool clear_site_specific; | 111 bool clear_site_specific; |
| 112 | 112 |
| 113 // Used by SET_SITE_PERMISSION. | 113 // Used by SET_SITE_PERMISSION. |
| 114 ppapi::FlashSiteSettings sites; | 114 ppapi::FlashSiteSettings sites; |
| 115 | 115 |
| 116 // Used by CLEAR_SITE_DATA | 116 // Used by CLEAR_SITE_DATA |
| 117 std::string site; | 117 std::string site; |
| 118 uint64 flags; | 118 uint64_t flags; |
| 119 uint64 max_age; | 119 uint64_t max_age; |
| 120 }; | 120 }; |
| 121 | 121 |
| 122 ~Core() override; | 122 ~Core() override; |
| 123 | 123 |
| 124 void ConnectToChannel(bool success, const IPC::ChannelHandle& handle); | 124 void ConnectToChannel(bool success, const IPC::ChannelHandle& handle); |
| 125 | 125 |
| 126 void InitializeOnIOThread(); | 126 void InitializeOnIOThread(); |
| 127 void DeauthorizeContentLicensesOnIOThread(uint32 request_id); | 127 void DeauthorizeContentLicensesOnIOThread(uint32_t request_id); |
| 128 void DeauthorizeContentLicensesOnBlockingPool( | 128 void DeauthorizeContentLicensesOnBlockingPool( |
| 129 uint32 request_id, | 129 uint32_t request_id, |
| 130 const base::FilePath& profile_path); | 130 const base::FilePath& profile_path); |
| 131 void DeauthorizeContentLicensesInPlugin(uint32 request_id, bool success); | 131 void DeauthorizeContentLicensesInPlugin(uint32_t request_id, bool success); |
| 132 void GetPermissionSettingsOnIOThread( | 132 void GetPermissionSettingsOnIOThread( |
| 133 uint32 request_id, | 133 uint32_t request_id, |
| 134 PP_Flash_BrowserOperations_SettingType setting_type); | 134 PP_Flash_BrowserOperations_SettingType setting_type); |
| 135 void SetDefaultPermissionOnIOThread( | 135 void SetDefaultPermissionOnIOThread( |
| 136 uint32 request_id, | 136 uint32_t request_id, |
| 137 PP_Flash_BrowserOperations_SettingType setting_type, | 137 PP_Flash_BrowserOperations_SettingType setting_type, |
| 138 PP_Flash_BrowserOperations_Permission permission, | 138 PP_Flash_BrowserOperations_Permission permission, |
| 139 bool clear_site_specific); | 139 bool clear_site_specific); |
| 140 void SetSitePermissionOnIOThread( | 140 void SetSitePermissionOnIOThread( |
| 141 uint32 request_id, | 141 uint32_t request_id, |
| 142 PP_Flash_BrowserOperations_SettingType setting_type, | 142 PP_Flash_BrowserOperations_SettingType setting_type, |
| 143 const ppapi::FlashSiteSettings& sites); | 143 const ppapi::FlashSiteSettings& sites); |
| 144 void GetSitesWithDataOnIOThread(uint32 request_id); | 144 void GetSitesWithDataOnIOThread(uint32_t request_id); |
| 145 void ClearSiteDataOnIOThread(uint32 request_id, | 145 void ClearSiteDataOnIOThread(uint32_t request_id, |
| 146 const std::string& site, | 146 const std::string& site, |
| 147 uint64 flags, | 147 uint64_t flags, |
| 148 uint64 max_age); | 148 uint64_t max_age); |
| 149 void DetachOnIOThread(); | 149 void DetachOnIOThread(); |
| 150 | 150 |
| 151 void NotifyErrorFromIOThread(); | 151 void NotifyErrorFromIOThread(); |
| 152 | 152 |
| 153 void NotifyDeauthorizeContentLicensesCompleted(uint32 request_id, | 153 void NotifyDeauthorizeContentLicensesCompleted(uint32_t request_id, |
| 154 bool success); | 154 bool success); |
| 155 void NotifyGetPermissionSettingsCompleted( | 155 void NotifyGetPermissionSettingsCompleted( |
| 156 uint32 request_id, | 156 uint32_t request_id, |
| 157 bool success, | 157 bool success, |
| 158 PP_Flash_BrowserOperations_Permission default_permission, | 158 PP_Flash_BrowserOperations_Permission default_permission, |
| 159 const ppapi::FlashSiteSettings& sites); | 159 const ppapi::FlashSiteSettings& sites); |
| 160 void NotifySetDefaultPermissionCompleted(uint32 request_id, bool success); | 160 void NotifySetDefaultPermissionCompleted(uint32_t request_id, bool success); |
| 161 void NotifySetSitePermissionCompleted(uint32 request_id, bool success); | 161 void NotifySetSitePermissionCompleted(uint32_t request_id, bool success); |
| 162 void NotifyGetSitesWithDataCompleted(uint32 request_id, | 162 void NotifyGetSitesWithDataCompleted(uint32_t request_id, |
| 163 const std::vector<std::string>& sites); | 163 const std::vector<std::string>& sites); |
| 164 void NotifyClearSiteDataCompleted(uint32 request_id, bool success); | 164 void NotifyClearSiteDataCompleted(uint32_t request_id, bool success); |
| 165 | 165 |
| 166 void NotifyError( | 166 void NotifyError( |
| 167 const std::vector<std::pair<uint32, RequestType> >& notifications); | 167 const std::vector<std::pair<uint32_t, RequestType>>& notifications); |
| 168 | 168 |
| 169 // Message handlers. | 169 // Message handlers. |
| 170 void OnDeauthorizeContentLicensesResult(uint32 request_id, bool success); | 170 void OnDeauthorizeContentLicensesResult(uint32_t request_id, bool success); |
| 171 void OnGetPermissionSettingsResult( | 171 void OnGetPermissionSettingsResult( |
| 172 uint32 request_id, | 172 uint32_t request_id, |
| 173 bool success, | 173 bool success, |
| 174 PP_Flash_BrowserOperations_Permission default_permission, | 174 PP_Flash_BrowserOperations_Permission default_permission, |
| 175 const ppapi::FlashSiteSettings& sites); | 175 const ppapi::FlashSiteSettings& sites); |
| 176 void OnSetDefaultPermissionResult(uint32 request_id, bool success); | 176 void OnSetDefaultPermissionResult(uint32_t request_id, bool success); |
| 177 void OnSetSitePermissionResult(uint32 request_id, bool success); | 177 void OnSetSitePermissionResult(uint32_t request_id, bool success); |
| 178 void OnGetSitesWithDataResult(uint32 request_id, | 178 void OnGetSitesWithDataResult(uint32_t request_id, |
| 179 const std::vector<std::string>& sites); | 179 const std::vector<std::string>& sites); |
| 180 void OnClearSiteDataResult(uint32 request_id, bool success); | 180 void OnClearSiteDataResult(uint32_t request_id, bool success); |
| 181 | 181 |
| 182 // Used only on the UI thread. | 182 // Used only on the UI thread. |
| 183 base::WeakPtr<PepperFlashSettingsManager> manager_; | 183 base::WeakPtr<PepperFlashSettingsManager> manager_; |
| 184 | 184 |
| 185 // Used only on the I/O thread. | 185 // Used only on the I/O thread. |
| 186 base::FilePath plugin_data_path_; | 186 base::FilePath plugin_data_path_; |
| 187 | 187 |
| 188 // The channel is NULL until we have opened a connection to the broker | 188 // The channel is NULL until we have opened a connection to the broker |
| 189 // process. Used only on the I/O thread. | 189 // process. Used only on the I/O thread. |
| 190 scoped_ptr<IPC::Channel> channel_; | 190 scoped_ptr<IPC::Channel> channel_; |
| 191 | 191 |
| 192 // Used only on the I/O thread. | 192 // Used only on the I/O thread. |
| 193 State state_; | 193 State state_; |
| 194 | 194 |
| 195 // Requests that need to be sent once the channel to the broker process is | 195 // Requests that need to be sent once the channel to the broker process is |
| 196 // established. Used only on the I/O thread. | 196 // established. Used only on the I/O thread. |
| 197 std::vector<PendingRequest> pending_requests_; | 197 std::vector<PendingRequest> pending_requests_; |
| 198 // Requests that have been sent but haven't got replied. Used only on the | 198 // Requests that have been sent but haven't got replied. Used only on the |
| 199 // I/O thread. | 199 // I/O thread. |
| 200 std::map<uint32, RequestType> pending_responses_; | 200 std::map<uint32_t, RequestType> pending_responses_; |
| 201 | 201 |
| 202 // Used only on the I/O thread. | 202 // Used only on the I/O thread. |
| 203 scoped_refptr<content::PepperFlashSettingsHelper> helper_; | 203 scoped_refptr<content::PepperFlashSettingsHelper> helper_; |
| 204 | 204 |
| 205 // Path for the current profile. Must be retrieved on the UI thread from the | 205 // Path for the current profile. Must be retrieved on the UI thread from the |
| 206 // browser context when we start so we can use it later on the I/O thread. | 206 // browser context when we start so we can use it later on the I/O thread. |
| 207 base::FilePath browser_context_path_; | 207 base::FilePath browser_context_path_; |
| 208 | 208 |
| 209 scoped_refptr<PluginPrefs> plugin_prefs_; | 209 scoped_refptr<PluginPrefs> plugin_prefs_; |
| 210 }; | 210 }; |
| (...skipping 25 matching lines...) Expand all Loading... |
| 236 // This call guarantees that one ref is retained until we get to the DETACHED | 236 // This call guarantees that one ref is retained until we get to the DETACHED |
| 237 // state. This is important. Otherwise, if the ref count drops to zero on the | 237 // state. This is important. Otherwise, if the ref count drops to zero on the |
| 238 // UI thread (which posts a task to delete this object on the I/O thread) | 238 // UI thread (which posts a task to delete this object on the I/O thread) |
| 239 // while the I/O thread doesn't know about it, methods on the I/O thread might | 239 // while the I/O thread doesn't know about it, methods on the I/O thread might |
| 240 // increase the ref count again and cause double deletion. | 240 // increase the ref count again and cause double deletion. |
| 241 BrowserThread::PostTask( | 241 BrowserThread::PostTask( |
| 242 BrowserThread::IO, FROM_HERE, base::Bind(&Core::DetachOnIOThread, this)); | 242 BrowserThread::IO, FROM_HERE, base::Bind(&Core::DetachOnIOThread, this)); |
| 243 } | 243 } |
| 244 | 244 |
| 245 void PepperFlashSettingsManager::Core::DeauthorizeContentLicenses( | 245 void PepperFlashSettingsManager::Core::DeauthorizeContentLicenses( |
| 246 uint32 request_id) { | 246 uint32_t request_id) { |
| 247 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 247 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 248 | 248 |
| 249 BrowserThread::PostTask( | 249 BrowserThread::PostTask( |
| 250 BrowserThread::IO, FROM_HERE, | 250 BrowserThread::IO, FROM_HERE, |
| 251 base::Bind(&Core::DeauthorizeContentLicensesOnIOThread, this, | 251 base::Bind(&Core::DeauthorizeContentLicensesOnIOThread, this, |
| 252 request_id)); | 252 request_id)); |
| 253 } | 253 } |
| 254 | 254 |
| 255 void PepperFlashSettingsManager::Core::GetPermissionSettings( | 255 void PepperFlashSettingsManager::Core::GetPermissionSettings( |
| 256 uint32 request_id, | 256 uint32_t request_id, |
| 257 PP_Flash_BrowserOperations_SettingType setting_type) { | 257 PP_Flash_BrowserOperations_SettingType setting_type) { |
| 258 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 258 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 259 | 259 |
| 260 BrowserThread::PostTask( | 260 BrowserThread::PostTask( |
| 261 BrowserThread::IO, FROM_HERE, | 261 BrowserThread::IO, FROM_HERE, |
| 262 base::Bind(&Core::GetPermissionSettingsOnIOThread, this, request_id, | 262 base::Bind(&Core::GetPermissionSettingsOnIOThread, this, request_id, |
| 263 setting_type)); | 263 setting_type)); |
| 264 } | 264 } |
| 265 | 265 |
| 266 void PepperFlashSettingsManager::Core::SetDefaultPermission( | 266 void PepperFlashSettingsManager::Core::SetDefaultPermission( |
| 267 uint32 request_id, | 267 uint32_t request_id, |
| 268 PP_Flash_BrowserOperations_SettingType setting_type, | 268 PP_Flash_BrowserOperations_SettingType setting_type, |
| 269 PP_Flash_BrowserOperations_Permission permission, | 269 PP_Flash_BrowserOperations_Permission permission, |
| 270 bool clear_site_specific) { | 270 bool clear_site_specific) { |
| 271 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 271 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 272 | 272 |
| 273 BrowserThread::PostTask( | 273 BrowserThread::PostTask( |
| 274 BrowserThread::IO, FROM_HERE, | 274 BrowserThread::IO, FROM_HERE, |
| 275 base::Bind(&Core::SetDefaultPermissionOnIOThread, this, request_id, | 275 base::Bind(&Core::SetDefaultPermissionOnIOThread, this, request_id, |
| 276 setting_type, permission, clear_site_specific)); | 276 setting_type, permission, clear_site_specific)); |
| 277 } | 277 } |
| 278 | 278 |
| 279 void PepperFlashSettingsManager::Core::SetSitePermission( | 279 void PepperFlashSettingsManager::Core::SetSitePermission( |
| 280 uint32 request_id, | 280 uint32_t request_id, |
| 281 PP_Flash_BrowserOperations_SettingType setting_type, | 281 PP_Flash_BrowserOperations_SettingType setting_type, |
| 282 const ppapi::FlashSiteSettings& sites) { | 282 const ppapi::FlashSiteSettings& sites) { |
| 283 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 283 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 284 | 284 |
| 285 BrowserThread::PostTask( | 285 BrowserThread::PostTask( |
| 286 BrowserThread::IO, FROM_HERE, | 286 BrowserThread::IO, FROM_HERE, |
| 287 base::Bind(&Core::SetSitePermissionOnIOThread, this, request_id, | 287 base::Bind(&Core::SetSitePermissionOnIOThread, this, request_id, |
| 288 setting_type, sites)); | 288 setting_type, sites)); |
| 289 } | 289 } |
| 290 | 290 |
| 291 void PepperFlashSettingsManager::Core::GetSitesWithData(uint32 request_id) { | 291 void PepperFlashSettingsManager::Core::GetSitesWithData(uint32_t request_id) { |
| 292 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 292 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 293 | 293 |
| 294 BrowserThread::PostTask( | 294 BrowserThread::PostTask( |
| 295 BrowserThread::IO, FROM_HERE, | 295 BrowserThread::IO, FROM_HERE, |
| 296 base::Bind(&Core::GetSitesWithDataOnIOThread, this, request_id)); | 296 base::Bind(&Core::GetSitesWithDataOnIOThread, this, request_id)); |
| 297 } | 297 } |
| 298 | 298 |
| 299 void PepperFlashSettingsManager::Core::ClearSiteData(uint32 request_id, | 299 void PepperFlashSettingsManager::Core::ClearSiteData(uint32_t request_id, |
| 300 const std::string& site, | 300 const std::string& site, |
| 301 uint64 flags, | 301 uint64_t flags, |
| 302 uint64 max_age) { | 302 uint64_t max_age) { |
| 303 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 303 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 304 | 304 |
| 305 BrowserThread::PostTask( | 305 BrowserThread::PostTask( |
| 306 BrowserThread::IO, FROM_HERE, | 306 BrowserThread::IO, FROM_HERE, |
| 307 base::Bind(&Core::ClearSiteDataOnIOThread, this, request_id, | 307 base::Bind(&Core::ClearSiteDataOnIOThread, this, request_id, |
| 308 site, flags, max_age)); | 308 site, flags, max_age)); |
| 309 } | 309 } |
| 310 | 310 |
| 311 bool PepperFlashSettingsManager::Core::OnMessageReceived( | 311 bool PepperFlashSettingsManager::Core::OnMessageReceived( |
| 312 const IPC::Message& message) { | 312 const IPC::Message& message) { |
| (...skipping 102 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 415 plugin_data_path_ = profile_path.Append(base::UTF16ToUTF8(plugin_info.name)); | 415 plugin_data_path_ = profile_path.Append(base::UTF16ToUTF8(plugin_info.name)); |
| 416 #endif | 416 #endif |
| 417 | 417 |
| 418 helper_ = content::PepperFlashSettingsHelper::Create(); | 418 helper_ = content::PepperFlashSettingsHelper::Create(); |
| 419 content::PepperFlashSettingsHelper::OpenChannelCallback callback = | 419 content::PepperFlashSettingsHelper::OpenChannelCallback callback = |
| 420 base::Bind(&Core::ConnectToChannel, this); | 420 base::Bind(&Core::ConnectToChannel, this); |
| 421 helper_->OpenChannelToBroker(plugin_info.path, callback); | 421 helper_->OpenChannelToBroker(plugin_info.path, callback); |
| 422 } | 422 } |
| 423 | 423 |
| 424 void PepperFlashSettingsManager::Core::DeauthorizeContentLicensesOnIOThread( | 424 void PepperFlashSettingsManager::Core::DeauthorizeContentLicensesOnIOThread( |
| 425 uint32 request_id) { | 425 uint32_t request_id) { |
| 426 DCHECK_CURRENTLY_ON(BrowserThread::IO); | 426 DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| 427 DCHECK_NE(STATE_DETACHED, state_); | 427 DCHECK_NE(STATE_DETACHED, state_); |
| 428 | 428 |
| 429 if (state_ == STATE_UNINITIALIZED) { | 429 if (state_ == STATE_UNINITIALIZED) { |
| 430 PendingRequest request; | 430 PendingRequest request; |
| 431 request.id = request_id; | 431 request.id = request_id; |
| 432 request.type = DEAUTHORIZE_CONTENT_LICENSES; | 432 request.type = DEAUTHORIZE_CONTENT_LICENSES; |
| 433 pending_requests_.push_back(request); | 433 pending_requests_.push_back(request); |
| 434 return; | 434 return; |
| 435 } | 435 } |
| (...skipping 11 matching lines...) Expand all Loading... |
| 447 request_id, browser_context_path_)); | 447 request_id, browser_context_path_)); |
| 448 #else | 448 #else |
| 449 DeauthorizeContentLicensesInPlugin(request_id, true); | 449 DeauthorizeContentLicensesInPlugin(request_id, true); |
| 450 #endif | 450 #endif |
| 451 } | 451 } |
| 452 | 452 |
| 453 // TODO(raymes): This is temporary code to migrate ChromeOS devices to the new | 453 // TODO(raymes): This is temporary code to migrate ChromeOS devices to the new |
| 454 // scheme for generating device IDs. Delete this once we are sure most ChromeOS | 454 // scheme for generating device IDs. Delete this once we are sure most ChromeOS |
| 455 // devices have been migrated. | 455 // devices have been migrated. |
| 456 void PepperFlashSettingsManager::Core::DeauthorizeContentLicensesOnBlockingPool( | 456 void PepperFlashSettingsManager::Core::DeauthorizeContentLicensesOnBlockingPool( |
| 457 uint32 request_id, | 457 uint32_t request_id, |
| 458 const base::FilePath& profile_path) { | 458 const base::FilePath& profile_path) { |
| 459 // ChromeOS used to store the device ID in a file but this is no longer used. | 459 // ChromeOS used to store the device ID in a file but this is no longer used. |
| 460 // Wipe that file. | 460 // Wipe that file. |
| 461 const base::FilePath& device_id_path = | 461 const base::FilePath& device_id_path = |
| 462 chrome::DeviceIDFetcher::GetLegacyDeviceIDPath(profile_path); | 462 chrome::DeviceIDFetcher::GetLegacyDeviceIDPath(profile_path); |
| 463 bool success = base::DeleteFile(device_id_path, false); | 463 bool success = base::DeleteFile(device_id_path, false); |
| 464 | 464 |
| 465 BrowserThread::PostTask( | 465 BrowserThread::PostTask( |
| 466 BrowserThread::IO, FROM_HERE, | 466 BrowserThread::IO, FROM_HERE, |
| 467 base::Bind(&Core::DeauthorizeContentLicensesInPlugin, this, request_id, | 467 base::Bind(&Core::DeauthorizeContentLicensesInPlugin, this, request_id, |
| 468 success)); | 468 success)); |
| 469 } | 469 } |
| 470 | 470 |
| 471 void PepperFlashSettingsManager::Core::DeauthorizeContentLicensesInPlugin( | 471 void PepperFlashSettingsManager::Core::DeauthorizeContentLicensesInPlugin( |
| 472 uint32 request_id, | 472 uint32_t request_id, |
| 473 bool success) { | 473 bool success) { |
| 474 DCHECK_CURRENTLY_ON(BrowserThread::IO); | 474 DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| 475 if (!success) { | 475 if (!success) { |
| 476 NotifyErrorFromIOThread(); | 476 NotifyErrorFromIOThread(); |
| 477 return; | 477 return; |
| 478 } | 478 } |
| 479 IPC::Message* msg = | 479 IPC::Message* msg = |
| 480 new PpapiMsg_DeauthorizeContentLicenses(request_id, plugin_data_path_); | 480 new PpapiMsg_DeauthorizeContentLicenses(request_id, plugin_data_path_); |
| 481 if (!channel_->Send(msg)) { | 481 if (!channel_->Send(msg)) { |
| 482 DLOG(ERROR) << "Couldn't send DeauthorizeContentLicenses message"; | 482 DLOG(ERROR) << "Couldn't send DeauthorizeContentLicenses message"; |
| 483 // A failure notification for the current request will be sent since | 483 // A failure notification for the current request will be sent since |
| 484 // |pending_responses_| has been updated. | 484 // |pending_responses_| has been updated. |
| 485 NotifyErrorFromIOThread(); | 485 NotifyErrorFromIOThread(); |
| 486 } | 486 } |
| 487 } | 487 } |
| 488 | 488 |
| 489 void PepperFlashSettingsManager::Core::GetPermissionSettingsOnIOThread( | 489 void PepperFlashSettingsManager::Core::GetPermissionSettingsOnIOThread( |
| 490 uint32 request_id, | 490 uint32_t request_id, |
| 491 PP_Flash_BrowserOperations_SettingType setting_type) { | 491 PP_Flash_BrowserOperations_SettingType setting_type) { |
| 492 DCHECK_CURRENTLY_ON(BrowserThread::IO); | 492 DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| 493 DCHECK_NE(STATE_DETACHED, state_); | 493 DCHECK_NE(STATE_DETACHED, state_); |
| 494 | 494 |
| 495 if (state_ == STATE_UNINITIALIZED) { | 495 if (state_ == STATE_UNINITIALIZED) { |
| 496 PendingRequest request; | 496 PendingRequest request; |
| 497 request.id = request_id; | 497 request.id = request_id; |
| 498 request.type = GET_PERMISSION_SETTINGS; | 498 request.type = GET_PERMISSION_SETTINGS; |
| 499 request.setting_type = setting_type; | 499 request.setting_type = setting_type; |
| 500 pending_requests_.push_back(request); | 500 pending_requests_.push_back(request); |
| (...skipping 11 matching lines...) Expand all Loading... |
| 512 request_id, plugin_data_path_, setting_type); | 512 request_id, plugin_data_path_, setting_type); |
| 513 if (!channel_->Send(msg)) { | 513 if (!channel_->Send(msg)) { |
| 514 DLOG(ERROR) << "Couldn't send GetPermissionSettings message"; | 514 DLOG(ERROR) << "Couldn't send GetPermissionSettings message"; |
| 515 // A failure notification for the current request will be sent since | 515 // A failure notification for the current request will be sent since |
| 516 // |pending_responses_| has been updated. | 516 // |pending_responses_| has been updated. |
| 517 NotifyErrorFromIOThread(); | 517 NotifyErrorFromIOThread(); |
| 518 } | 518 } |
| 519 } | 519 } |
| 520 | 520 |
| 521 void PepperFlashSettingsManager::Core::SetDefaultPermissionOnIOThread( | 521 void PepperFlashSettingsManager::Core::SetDefaultPermissionOnIOThread( |
| 522 uint32 request_id, | 522 uint32_t request_id, |
| 523 PP_Flash_BrowserOperations_SettingType setting_type, | 523 PP_Flash_BrowserOperations_SettingType setting_type, |
| 524 PP_Flash_BrowserOperations_Permission permission, | 524 PP_Flash_BrowserOperations_Permission permission, |
| 525 bool clear_site_specific) { | 525 bool clear_site_specific) { |
| 526 DCHECK_CURRENTLY_ON(BrowserThread::IO); | 526 DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| 527 DCHECK_NE(STATE_DETACHED, state_); | 527 DCHECK_NE(STATE_DETACHED, state_); |
| 528 | 528 |
| 529 if (state_ == STATE_UNINITIALIZED) { | 529 if (state_ == STATE_UNINITIALIZED) { |
| 530 PendingRequest request; | 530 PendingRequest request; |
| 531 request.id = request_id; | 531 request.id = request_id; |
| 532 request.type = SET_DEFAULT_PERMISSION; | 532 request.type = SET_DEFAULT_PERMISSION; |
| (...skipping 15 matching lines...) Expand all Loading... |
| 548 clear_site_specific); | 548 clear_site_specific); |
| 549 if (!channel_->Send(msg)) { | 549 if (!channel_->Send(msg)) { |
| 550 DLOG(ERROR) << "Couldn't send SetDefaultPermission message"; | 550 DLOG(ERROR) << "Couldn't send SetDefaultPermission message"; |
| 551 // A failure notification for the current request will be sent since | 551 // A failure notification for the current request will be sent since |
| 552 // |pending_responses_| has been updated. | 552 // |pending_responses_| has been updated. |
| 553 NotifyErrorFromIOThread(); | 553 NotifyErrorFromIOThread(); |
| 554 } | 554 } |
| 555 } | 555 } |
| 556 | 556 |
| 557 void PepperFlashSettingsManager::Core::SetSitePermissionOnIOThread( | 557 void PepperFlashSettingsManager::Core::SetSitePermissionOnIOThread( |
| 558 uint32 request_id, | 558 uint32_t request_id, |
| 559 PP_Flash_BrowserOperations_SettingType setting_type, | 559 PP_Flash_BrowserOperations_SettingType setting_type, |
| 560 const ppapi::FlashSiteSettings& sites) { | 560 const ppapi::FlashSiteSettings& sites) { |
| 561 DCHECK_CURRENTLY_ON(BrowserThread::IO); | 561 DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| 562 DCHECK_NE(STATE_DETACHED, state_); | 562 DCHECK_NE(STATE_DETACHED, state_); |
| 563 | 563 |
| 564 if (state_ == STATE_UNINITIALIZED) { | 564 if (state_ == STATE_UNINITIALIZED) { |
| 565 pending_requests_.push_back(PendingRequest()); | 565 pending_requests_.push_back(PendingRequest()); |
| 566 PendingRequest& request = pending_requests_.back(); | 566 PendingRequest& request = pending_requests_.back(); |
| 567 request.id = request_id; | 567 request.id = request_id; |
| 568 request.type = SET_SITE_PERMISSION; | 568 request.type = SET_SITE_PERMISSION; |
| (...skipping 12 matching lines...) Expand all Loading... |
| 581 request_id, plugin_data_path_, setting_type, sites); | 581 request_id, plugin_data_path_, setting_type, sites); |
| 582 if (!channel_->Send(msg)) { | 582 if (!channel_->Send(msg)) { |
| 583 DLOG(ERROR) << "Couldn't send SetSitePermission message"; | 583 DLOG(ERROR) << "Couldn't send SetSitePermission message"; |
| 584 // A failure notification for the current request will be sent since | 584 // A failure notification for the current request will be sent since |
| 585 // |pending_responses_| has been updated. | 585 // |pending_responses_| has been updated. |
| 586 NotifyErrorFromIOThread(); | 586 NotifyErrorFromIOThread(); |
| 587 } | 587 } |
| 588 } | 588 } |
| 589 | 589 |
| 590 void PepperFlashSettingsManager::Core::GetSitesWithDataOnIOThread( | 590 void PepperFlashSettingsManager::Core::GetSitesWithDataOnIOThread( |
| 591 uint32 request_id) { | 591 uint32_t request_id) { |
| 592 DCHECK_CURRENTLY_ON(BrowserThread::IO); | 592 DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| 593 DCHECK_NE(STATE_DETACHED, state_); | 593 DCHECK_NE(STATE_DETACHED, state_); |
| 594 | 594 |
| 595 if (state_ == STATE_UNINITIALIZED) { | 595 if (state_ == STATE_UNINITIALIZED) { |
| 596 pending_requests_.push_back(PendingRequest()); | 596 pending_requests_.push_back(PendingRequest()); |
| 597 PendingRequest& request = pending_requests_.back(); | 597 PendingRequest& request = pending_requests_.back(); |
| 598 request.id = request_id; | 598 request.id = request_id; |
| 599 request.type = GET_SITES_WITH_DATA; | 599 request.type = GET_SITES_WITH_DATA; |
| 600 return; | 600 return; |
| 601 } | 601 } |
| 602 | 602 |
| 603 pending_responses_.insert(std::make_pair(request_id, GET_SITES_WITH_DATA)); | 603 pending_responses_.insert(std::make_pair(request_id, GET_SITES_WITH_DATA)); |
| 604 if (state_ == STATE_ERROR) { | 604 if (state_ == STATE_ERROR) { |
| 605 NotifyErrorFromIOThread(); | 605 NotifyErrorFromIOThread(); |
| 606 return; | 606 return; |
| 607 } | 607 } |
| 608 | 608 |
| 609 IPC::Message* msg = new PpapiMsg_GetSitesWithData( | 609 IPC::Message* msg = new PpapiMsg_GetSitesWithData( |
| 610 request_id, plugin_data_path_); | 610 request_id, plugin_data_path_); |
| 611 if (!channel_->Send(msg)) { | 611 if (!channel_->Send(msg)) { |
| 612 DLOG(ERROR) << "Couldn't send GetSitesWithData message"; | 612 DLOG(ERROR) << "Couldn't send GetSitesWithData message"; |
| 613 // A failure notification for the current request will be sent since | 613 // A failure notification for the current request will be sent since |
| 614 // |pending_responses_| has been updated. | 614 // |pending_responses_| has been updated. |
| 615 NotifyErrorFromIOThread(); | 615 NotifyErrorFromIOThread(); |
| 616 } | 616 } |
| 617 } | 617 } |
| 618 | 618 |
| 619 void PepperFlashSettingsManager::Core::ClearSiteDataOnIOThread( | 619 void PepperFlashSettingsManager::Core::ClearSiteDataOnIOThread( |
| 620 uint32 request_id, | 620 uint32_t request_id, |
| 621 const std::string& site, | 621 const std::string& site, |
| 622 uint64 flags, | 622 uint64_t flags, |
| 623 uint64 max_age) { | 623 uint64_t max_age) { |
| 624 DCHECK_CURRENTLY_ON(BrowserThread::IO); | 624 DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| 625 DCHECK_NE(STATE_DETACHED, state_); | 625 DCHECK_NE(STATE_DETACHED, state_); |
| 626 | 626 |
| 627 if (state_ == STATE_UNINITIALIZED) { | 627 if (state_ == STATE_UNINITIALIZED) { |
| 628 pending_requests_.push_back(PendingRequest()); | 628 pending_requests_.push_back(PendingRequest()); |
| 629 PendingRequest& request = pending_requests_.back(); | 629 PendingRequest& request = pending_requests_.back(); |
| 630 request.id = request_id; | 630 request.id = request_id; |
| 631 request.type = CLEAR_SITE_DATA; | 631 request.type = CLEAR_SITE_DATA; |
| 632 request.site = site; | 632 request.site = site; |
| 633 request.flags = flags; | 633 request.flags = flags; |
| (...skipping 20 matching lines...) Expand all Loading... |
| 654 void PepperFlashSettingsManager::Core::DetachOnIOThread() { | 654 void PepperFlashSettingsManager::Core::DetachOnIOThread() { |
| 655 state_ = STATE_DETACHED; | 655 state_ = STATE_DETACHED; |
| 656 } | 656 } |
| 657 | 657 |
| 658 void PepperFlashSettingsManager::Core::NotifyErrorFromIOThread() { | 658 void PepperFlashSettingsManager::Core::NotifyErrorFromIOThread() { |
| 659 DCHECK_CURRENTLY_ON(BrowserThread::IO); | 659 DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| 660 if (state_ == STATE_DETACHED) | 660 if (state_ == STATE_DETACHED) |
| 661 return; | 661 return; |
| 662 | 662 |
| 663 state_ = STATE_ERROR; | 663 state_ = STATE_ERROR; |
| 664 std::vector<std::pair<uint32, RequestType> > notifications; | 664 std::vector<std::pair<uint32_t, RequestType>> notifications; |
| 665 for (std::vector<PendingRequest>::iterator iter = pending_requests_.begin(); | 665 for (std::vector<PendingRequest>::iterator iter = pending_requests_.begin(); |
| 666 iter != pending_requests_.end(); ++iter) { | 666 iter != pending_requests_.end(); ++iter) { |
| 667 notifications.push_back(std::make_pair(iter->id, iter->type)); | 667 notifications.push_back(std::make_pair(iter->id, iter->type)); |
| 668 } | 668 } |
| 669 pending_requests_.clear(); | 669 pending_requests_.clear(); |
| 670 notifications.insert(notifications.end(), pending_responses_.begin(), | 670 notifications.insert(notifications.end(), pending_responses_.begin(), |
| 671 pending_responses_.end()); | 671 pending_responses_.end()); |
| 672 pending_responses_.clear(); | 672 pending_responses_.clear(); |
| 673 | 673 |
| 674 BrowserThread::PostTask( | 674 BrowserThread::PostTask( |
| 675 BrowserThread::UI, FROM_HERE, | 675 BrowserThread::UI, FROM_HERE, |
| 676 base::Bind(&Core::NotifyError, this, notifications)); | 676 base::Bind(&Core::NotifyError, this, notifications)); |
| 677 } | 677 } |
| 678 | 678 |
| 679 void | 679 void PepperFlashSettingsManager::Core:: |
| 680 PepperFlashSettingsManager::Core::NotifyDeauthorizeContentLicensesCompleted( | 680 NotifyDeauthorizeContentLicensesCompleted(uint32_t request_id, |
| 681 uint32 request_id, | 681 bool success) { |
| 682 bool success) { | |
| 683 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 682 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 684 | 683 |
| 685 if (manager_.get()) { | 684 if (manager_.get()) { |
| 686 manager_->client_->OnDeauthorizeContentLicensesCompleted( | 685 manager_->client_->OnDeauthorizeContentLicensesCompleted( |
| 687 request_id, success); | 686 request_id, success); |
| 688 } | 687 } |
| 689 } | 688 } |
| 690 | 689 |
| 691 void PepperFlashSettingsManager::Core::NotifyGetPermissionSettingsCompleted( | 690 void PepperFlashSettingsManager::Core::NotifyGetPermissionSettingsCompleted( |
| 692 uint32 request_id, | 691 uint32_t request_id, |
| 693 bool success, | 692 bool success, |
| 694 PP_Flash_BrowserOperations_Permission default_permission, | 693 PP_Flash_BrowserOperations_Permission default_permission, |
| 695 const ppapi::FlashSiteSettings& sites) { | 694 const ppapi::FlashSiteSettings& sites) { |
| 696 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 695 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 697 | 696 |
| 698 if (manager_.get()) { | 697 if (manager_.get()) { |
| 699 manager_->client_->OnGetPermissionSettingsCompleted( | 698 manager_->client_->OnGetPermissionSettingsCompleted( |
| 700 request_id, success, default_permission, sites); | 699 request_id, success, default_permission, sites); |
| 701 } | 700 } |
| 702 } | 701 } |
| 703 | 702 |
| 704 void PepperFlashSettingsManager::Core::NotifySetDefaultPermissionCompleted( | 703 void PepperFlashSettingsManager::Core::NotifySetDefaultPermissionCompleted( |
| 705 uint32 request_id, | 704 uint32_t request_id, |
| 706 bool success) { | 705 bool success) { |
| 707 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 706 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 708 | 707 |
| 709 if (manager_.get()) { | 708 if (manager_.get()) { |
| 710 manager_->client_->OnSetDefaultPermissionCompleted( | 709 manager_->client_->OnSetDefaultPermissionCompleted( |
| 711 request_id, success); | 710 request_id, success); |
| 712 } | 711 } |
| 713 } | 712 } |
| 714 | 713 |
| 715 void PepperFlashSettingsManager::Core::NotifySetSitePermissionCompleted( | 714 void PepperFlashSettingsManager::Core::NotifySetSitePermissionCompleted( |
| 716 uint32 request_id, | 715 uint32_t request_id, |
| 717 bool success) { | 716 bool success) { |
| 718 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 717 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 719 | 718 |
| 720 if (manager_.get()) { | 719 if (manager_.get()) { |
| 721 manager_->client_->OnSetSitePermissionCompleted( | 720 manager_->client_->OnSetSitePermissionCompleted( |
| 722 request_id, success); | 721 request_id, success); |
| 723 } | 722 } |
| 724 } | 723 } |
| 725 | 724 |
| 726 void PepperFlashSettingsManager::Core::NotifyGetSitesWithDataCompleted( | 725 void PepperFlashSettingsManager::Core::NotifyGetSitesWithDataCompleted( |
| 727 uint32 request_id, | 726 uint32_t request_id, |
| 728 const std::vector<std::string>& sites) { | 727 const std::vector<std::string>& sites) { |
| 729 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 728 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 730 | 729 |
| 731 if (manager_.get()) { | 730 if (manager_.get()) { |
| 732 manager_->client_->OnGetSitesWithDataCompleted( | 731 manager_->client_->OnGetSitesWithDataCompleted( |
| 733 request_id, sites); | 732 request_id, sites); |
| 734 } | 733 } |
| 735 } | 734 } |
| 736 | 735 |
| 737 void PepperFlashSettingsManager::Core::NotifyClearSiteDataCompleted( | 736 void PepperFlashSettingsManager::Core::NotifyClearSiteDataCompleted( |
| 738 uint32 request_id, | 737 uint32_t request_id, |
| 739 bool success) { | 738 bool success) { |
| 740 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 739 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 741 | 740 |
| 742 if (manager_.get()) | 741 if (manager_.get()) |
| 743 manager_->client_->OnClearSiteDataCompleted(request_id, success); | 742 manager_->client_->OnClearSiteDataCompleted(request_id, success); |
| 744 } | 743 } |
| 745 | 744 |
| 746 void PepperFlashSettingsManager::Core::NotifyError( | 745 void PepperFlashSettingsManager::Core::NotifyError( |
| 747 const std::vector<std::pair<uint32, RequestType> >& notifications) { | 746 const std::vector<std::pair<uint32_t, RequestType>>& notifications) { |
| 748 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 747 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 749 | 748 |
| 750 scoped_refptr<Core> protector(this); | 749 scoped_refptr<Core> protector(this); |
| 751 for (std::vector<std::pair<uint32, RequestType> >::const_iterator iter = | 750 for (std::vector<std::pair<uint32_t, RequestType>>::const_iterator iter = |
| 752 notifications.begin(); iter != notifications.end(); ++iter) { | 751 notifications.begin(); |
| 752 iter != notifications.end(); ++iter) { |
| 753 // Check |manager_| for each iteration in case it is destroyed in one of | 753 // Check |manager_| for each iteration in case it is destroyed in one of |
| 754 // the callbacks. | 754 // the callbacks. |
| 755 if (!manager_.get()) | 755 if (!manager_.get()) |
| 756 return; | 756 return; |
| 757 | 757 |
| 758 switch (iter->second) { | 758 switch (iter->second) { |
| 759 case INVALID_REQUEST_TYPE: | 759 case INVALID_REQUEST_TYPE: |
| 760 NOTREACHED(); | 760 NOTREACHED(); |
| 761 break; | 761 break; |
| 762 case DEAUTHORIZE_CONTENT_LICENSES: | 762 case DEAUTHORIZE_CONTENT_LICENSES: |
| (...skipping 20 matching lines...) Expand all Loading... |
| 783 manager_->client_->OnClearSiteDataCompleted(iter->first, false); | 783 manager_->client_->OnClearSiteDataCompleted(iter->first, false); |
| 784 break; | 784 break; |
| 785 } | 785 } |
| 786 } | 786 } |
| 787 | 787 |
| 788 if (manager_.get()) | 788 if (manager_.get()) |
| 789 manager_->OnError(this); | 789 manager_->OnError(this); |
| 790 } | 790 } |
| 791 | 791 |
| 792 void PepperFlashSettingsManager::Core::OnDeauthorizeContentLicensesResult( | 792 void PepperFlashSettingsManager::Core::OnDeauthorizeContentLicensesResult( |
| 793 uint32 request_id, | 793 uint32_t request_id, |
| 794 bool success) { | 794 bool success) { |
| 795 DCHECK_CURRENTLY_ON(BrowserThread::IO); | 795 DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| 796 if (state_ == STATE_DETACHED) | 796 if (state_ == STATE_DETACHED) |
| 797 return; | 797 return; |
| 798 | 798 |
| 799 DLOG_IF(ERROR, !success) << "DeauthorizeContentLicenses returned error"; | 799 DLOG_IF(ERROR, !success) << "DeauthorizeContentLicenses returned error"; |
| 800 | 800 |
| 801 std::map<uint32, RequestType>::iterator iter = | 801 std::map<uint32_t, RequestType>::iterator iter = |
| 802 pending_responses_.find(request_id); | 802 pending_responses_.find(request_id); |
| 803 if (iter == pending_responses_.end()) | 803 if (iter == pending_responses_.end()) |
| 804 return; | 804 return; |
| 805 | 805 |
| 806 DCHECK_EQ(iter->second, DEAUTHORIZE_CONTENT_LICENSES); | 806 DCHECK_EQ(iter->second, DEAUTHORIZE_CONTENT_LICENSES); |
| 807 | 807 |
| 808 pending_responses_.erase(iter); | 808 pending_responses_.erase(iter); |
| 809 BrowserThread::PostTask( | 809 BrowserThread::PostTask( |
| 810 BrowserThread::UI, FROM_HERE, | 810 BrowserThread::UI, FROM_HERE, |
| 811 base::Bind(&Core::NotifyDeauthorizeContentLicensesCompleted, this, | 811 base::Bind(&Core::NotifyDeauthorizeContentLicensesCompleted, this, |
| 812 request_id, success)); | 812 request_id, success)); |
| 813 } | 813 } |
| 814 | 814 |
| 815 void PepperFlashSettingsManager::Core::OnGetPermissionSettingsResult( | 815 void PepperFlashSettingsManager::Core::OnGetPermissionSettingsResult( |
| 816 uint32 request_id, | 816 uint32_t request_id, |
| 817 bool success, | 817 bool success, |
| 818 PP_Flash_BrowserOperations_Permission default_permission, | 818 PP_Flash_BrowserOperations_Permission default_permission, |
| 819 const ppapi::FlashSiteSettings& sites) { | 819 const ppapi::FlashSiteSettings& sites) { |
| 820 DCHECK_CURRENTLY_ON(BrowserThread::IO); | 820 DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| 821 if (state_ == STATE_DETACHED) | 821 if (state_ == STATE_DETACHED) |
| 822 return; | 822 return; |
| 823 | 823 |
| 824 DLOG_IF(ERROR, !success) << "GetPermissionSettings returned error"; | 824 DLOG_IF(ERROR, !success) << "GetPermissionSettings returned error"; |
| 825 | 825 |
| 826 std::map<uint32, RequestType>::iterator iter = | 826 std::map<uint32_t, RequestType>::iterator iter = |
| 827 pending_responses_.find(request_id); | 827 pending_responses_.find(request_id); |
| 828 if (iter == pending_responses_.end()) | 828 if (iter == pending_responses_.end()) |
| 829 return; | 829 return; |
| 830 | 830 |
| 831 DCHECK_EQ(iter->second, GET_PERMISSION_SETTINGS); | 831 DCHECK_EQ(iter->second, GET_PERMISSION_SETTINGS); |
| 832 | 832 |
| 833 pending_responses_.erase(iter); | 833 pending_responses_.erase(iter); |
| 834 BrowserThread::PostTask( | 834 BrowserThread::PostTask( |
| 835 BrowserThread::UI, FROM_HERE, | 835 BrowserThread::UI, FROM_HERE, |
| 836 base::Bind(&Core::NotifyGetPermissionSettingsCompleted, this, | 836 base::Bind(&Core::NotifyGetPermissionSettingsCompleted, this, |
| 837 request_id, success, default_permission, sites)); | 837 request_id, success, default_permission, sites)); |
| 838 } | 838 } |
| 839 | 839 |
| 840 void PepperFlashSettingsManager::Core::OnSetDefaultPermissionResult( | 840 void PepperFlashSettingsManager::Core::OnSetDefaultPermissionResult( |
| 841 uint32 request_id, | 841 uint32_t request_id, |
| 842 bool success) { | 842 bool success) { |
| 843 DCHECK_CURRENTLY_ON(BrowserThread::IO); | 843 DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| 844 if (state_ == STATE_DETACHED) | 844 if (state_ == STATE_DETACHED) |
| 845 return; | 845 return; |
| 846 | 846 |
| 847 DLOG_IF(ERROR, !success) << "SetDefaultPermission returned error"; | 847 DLOG_IF(ERROR, !success) << "SetDefaultPermission returned error"; |
| 848 | 848 |
| 849 std::map<uint32, RequestType>::iterator iter = | 849 std::map<uint32_t, RequestType>::iterator iter = |
| 850 pending_responses_.find(request_id); | 850 pending_responses_.find(request_id); |
| 851 if (iter == pending_responses_.end()) | 851 if (iter == pending_responses_.end()) |
| 852 return; | 852 return; |
| 853 | 853 |
| 854 DCHECK_EQ(iter->second, SET_DEFAULT_PERMISSION); | 854 DCHECK_EQ(iter->second, SET_DEFAULT_PERMISSION); |
| 855 | 855 |
| 856 pending_responses_.erase(iter); | 856 pending_responses_.erase(iter); |
| 857 BrowserThread::PostTask( | 857 BrowserThread::PostTask( |
| 858 BrowserThread::UI, FROM_HERE, | 858 BrowserThread::UI, FROM_HERE, |
| 859 base::Bind(&Core::NotifySetDefaultPermissionCompleted, this, | 859 base::Bind(&Core::NotifySetDefaultPermissionCompleted, this, |
| 860 request_id, success)); | 860 request_id, success)); |
| 861 } | 861 } |
| 862 | 862 |
| 863 void PepperFlashSettingsManager::Core::OnSetSitePermissionResult( | 863 void PepperFlashSettingsManager::Core::OnSetSitePermissionResult( |
| 864 uint32 request_id, | 864 uint32_t request_id, |
| 865 bool success) { | 865 bool success) { |
| 866 DCHECK_CURRENTLY_ON(BrowserThread::IO); | 866 DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| 867 if (state_ == STATE_DETACHED) | 867 if (state_ == STATE_DETACHED) |
| 868 return; | 868 return; |
| 869 | 869 |
| 870 DLOG_IF(ERROR, !success) << "SetSitePermission returned error"; | 870 DLOG_IF(ERROR, !success) << "SetSitePermission returned error"; |
| 871 | 871 |
| 872 std::map<uint32, RequestType>::iterator iter = | 872 std::map<uint32_t, RequestType>::iterator iter = |
| 873 pending_responses_.find(request_id); | 873 pending_responses_.find(request_id); |
| 874 if (iter == pending_responses_.end()) | 874 if (iter == pending_responses_.end()) |
| 875 return; | 875 return; |
| 876 | 876 |
| 877 DCHECK_EQ(iter->second, SET_SITE_PERMISSION); | 877 DCHECK_EQ(iter->second, SET_SITE_PERMISSION); |
| 878 | 878 |
| 879 pending_responses_.erase(iter); | 879 pending_responses_.erase(iter); |
| 880 BrowserThread::PostTask( | 880 BrowserThread::PostTask( |
| 881 BrowserThread::UI, FROM_HERE, | 881 BrowserThread::UI, FROM_HERE, |
| 882 base::Bind(&Core::NotifySetSitePermissionCompleted, this, request_id, | 882 base::Bind(&Core::NotifySetSitePermissionCompleted, this, request_id, |
| 883 success)); | 883 success)); |
| 884 } | 884 } |
| 885 | 885 |
| 886 void PepperFlashSettingsManager::Core::OnGetSitesWithDataResult( | 886 void PepperFlashSettingsManager::Core::OnGetSitesWithDataResult( |
| 887 uint32 request_id, | 887 uint32_t request_id, |
| 888 const std::vector<std::string>& sites) { | 888 const std::vector<std::string>& sites) { |
| 889 DCHECK_CURRENTLY_ON(BrowserThread::IO); | 889 DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| 890 if (state_ == STATE_DETACHED) | 890 if (state_ == STATE_DETACHED) |
| 891 return; | 891 return; |
| 892 | 892 |
| 893 std::map<uint32, RequestType>::iterator iter = | 893 std::map<uint32_t, RequestType>::iterator iter = |
| 894 pending_responses_.find(request_id); | 894 pending_responses_.find(request_id); |
| 895 if (iter == pending_responses_.end()) | 895 if (iter == pending_responses_.end()) |
| 896 return; | 896 return; |
| 897 | 897 |
| 898 DCHECK_EQ(iter->second, GET_SITES_WITH_DATA); | 898 DCHECK_EQ(iter->second, GET_SITES_WITH_DATA); |
| 899 | 899 |
| 900 pending_responses_.erase(iter); | 900 pending_responses_.erase(iter); |
| 901 BrowserThread::PostTask( | 901 BrowserThread::PostTask( |
| 902 BrowserThread::UI, FROM_HERE, | 902 BrowserThread::UI, FROM_HERE, |
| 903 base::Bind(&Core::NotifyGetSitesWithDataCompleted, this, request_id, | 903 base::Bind(&Core::NotifyGetSitesWithDataCompleted, this, request_id, |
| 904 sites)); | 904 sites)); |
| 905 } | 905 } |
| 906 | 906 |
| 907 void PepperFlashSettingsManager::Core::OnClearSiteDataResult( | 907 void PepperFlashSettingsManager::Core::OnClearSiteDataResult( |
| 908 uint32 request_id, | 908 uint32_t request_id, |
| 909 bool success) { | 909 bool success) { |
| 910 DCHECK_CURRENTLY_ON(BrowserThread::IO); | 910 DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| 911 if (state_ == STATE_DETACHED) | 911 if (state_ == STATE_DETACHED) |
| 912 return; | 912 return; |
| 913 | 913 |
| 914 DLOG_IF(ERROR, !success) << "ClearSiteData returned error"; | 914 DLOG_IF(ERROR, !success) << "ClearSiteData returned error"; |
| 915 | 915 |
| 916 std::map<uint32, RequestType>::iterator iter = | 916 std::map<uint32_t, RequestType>::iterator iter = |
| 917 pending_responses_.find(request_id); | 917 pending_responses_.find(request_id); |
| 918 if (iter == pending_responses_.end()) | 918 if (iter == pending_responses_.end()) |
| 919 return; | 919 return; |
| 920 | 920 |
| 921 DCHECK_EQ(iter->second, CLEAR_SITE_DATA); | 921 DCHECK_EQ(iter->second, CLEAR_SITE_DATA); |
| 922 | 922 |
| 923 pending_responses_.erase(iter); | 923 pending_responses_.erase(iter); |
| 924 BrowserThread::PostTask( | 924 BrowserThread::PostTask( |
| 925 BrowserThread::UI, FROM_HERE, | 925 BrowserThread::UI, FROM_HERE, |
| 926 base::Bind(&Core::NotifyClearSiteDataCompleted, this, request_id, | 926 base::Bind(&Core::NotifyClearSiteDataCompleted, this, request_id, |
| (...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 968 } | 968 } |
| 969 | 969 |
| 970 // static | 970 // static |
| 971 void PepperFlashSettingsManager::RegisterProfilePrefs( | 971 void PepperFlashSettingsManager::RegisterProfilePrefs( |
| 972 user_prefs::PrefRegistrySyncable* registry) { | 972 user_prefs::PrefRegistrySyncable* registry) { |
| 973 registry->RegisterBooleanPref(prefs::kDeauthorizeContentLicenses, false); | 973 registry->RegisterBooleanPref(prefs::kDeauthorizeContentLicenses, false); |
| 974 | 974 |
| 975 registry->RegisterBooleanPref(prefs::kPepperFlashSettingsEnabled, true); | 975 registry->RegisterBooleanPref(prefs::kPepperFlashSettingsEnabled, true); |
| 976 } | 976 } |
| 977 | 977 |
| 978 uint32 PepperFlashSettingsManager::DeauthorizeContentLicenses( | 978 uint32_t PepperFlashSettingsManager::DeauthorizeContentLicenses( |
| 979 PrefService* prefs) { | 979 PrefService* prefs) { |
| 980 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 980 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 981 | 981 |
| 982 // Clear the device ID salt which has the effect of regenerating a device | 982 // Clear the device ID salt which has the effect of regenerating a device |
| 983 // ID. Since this happens synchronously (and on the UI thread), we don't have | 983 // ID. Since this happens synchronously (and on the UI thread), we don't have |
| 984 // to add it to a pending request. | 984 // to add it to a pending request. |
| 985 prefs->ClearPref(prefs::kDRMSalt); | 985 prefs->ClearPref(prefs::kDRMSalt); |
| 986 | 986 |
| 987 EnsureCoreExists(); | 987 EnsureCoreExists(); |
| 988 uint32 id = GetNextRequestId(); | 988 uint32_t id = GetNextRequestId(); |
| 989 core_->DeauthorizeContentLicenses(id); | 989 core_->DeauthorizeContentLicenses(id); |
| 990 return id; | 990 return id; |
| 991 } | 991 } |
| 992 | 992 |
| 993 uint32 PepperFlashSettingsManager::GetPermissionSettings( | 993 uint32_t PepperFlashSettingsManager::GetPermissionSettings( |
| 994 PP_Flash_BrowserOperations_SettingType setting_type) { | 994 PP_Flash_BrowserOperations_SettingType setting_type) { |
| 995 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 995 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 996 | 996 |
| 997 EnsureCoreExists(); | 997 EnsureCoreExists(); |
| 998 uint32 id = GetNextRequestId(); | 998 uint32_t id = GetNextRequestId(); |
| 999 core_->GetPermissionSettings(id, setting_type); | 999 core_->GetPermissionSettings(id, setting_type); |
| 1000 return id; | 1000 return id; |
| 1001 } | 1001 } |
| 1002 | 1002 |
| 1003 uint32 PepperFlashSettingsManager::SetDefaultPermission( | 1003 uint32_t PepperFlashSettingsManager::SetDefaultPermission( |
| 1004 PP_Flash_BrowserOperations_SettingType setting_type, | 1004 PP_Flash_BrowserOperations_SettingType setting_type, |
| 1005 PP_Flash_BrowserOperations_Permission permission, | 1005 PP_Flash_BrowserOperations_Permission permission, |
| 1006 bool clear_site_specific) { | 1006 bool clear_site_specific) { |
| 1007 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 1007 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 1008 | 1008 |
| 1009 EnsureCoreExists(); | 1009 EnsureCoreExists(); |
| 1010 uint32 id = GetNextRequestId(); | 1010 uint32_t id = GetNextRequestId(); |
| 1011 core_->SetDefaultPermission(id, setting_type, permission, | 1011 core_->SetDefaultPermission(id, setting_type, permission, |
| 1012 clear_site_specific); | 1012 clear_site_specific); |
| 1013 return id; | 1013 return id; |
| 1014 } | 1014 } |
| 1015 | 1015 |
| 1016 uint32 PepperFlashSettingsManager::SetSitePermission( | 1016 uint32_t PepperFlashSettingsManager::SetSitePermission( |
| 1017 PP_Flash_BrowserOperations_SettingType setting_type, | 1017 PP_Flash_BrowserOperations_SettingType setting_type, |
| 1018 const ppapi::FlashSiteSettings& sites) { | 1018 const ppapi::FlashSiteSettings& sites) { |
| 1019 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 1019 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 1020 | 1020 |
| 1021 EnsureCoreExists(); | 1021 EnsureCoreExists(); |
| 1022 uint32 id = GetNextRequestId(); | 1022 uint32_t id = GetNextRequestId(); |
| 1023 core_->SetSitePermission(id, setting_type, sites); | 1023 core_->SetSitePermission(id, setting_type, sites); |
| 1024 return id; | 1024 return id; |
| 1025 } | 1025 } |
| 1026 | 1026 |
| 1027 uint32 PepperFlashSettingsManager::GetSitesWithData() { | 1027 uint32_t PepperFlashSettingsManager::GetSitesWithData() { |
| 1028 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 1028 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 1029 | 1029 |
| 1030 EnsureCoreExists(); | 1030 EnsureCoreExists(); |
| 1031 uint32 id = GetNextRequestId(); | 1031 uint32_t id = GetNextRequestId(); |
| 1032 core_->GetSitesWithData(id); | 1032 core_->GetSitesWithData(id); |
| 1033 return id; | 1033 return id; |
| 1034 } | 1034 } |
| 1035 | 1035 |
| 1036 uint32 PepperFlashSettingsManager::ClearSiteData(const std::string& site, | 1036 uint32_t PepperFlashSettingsManager::ClearSiteData(const std::string& site, |
| 1037 uint64 flags, | 1037 uint64_t flags, |
| 1038 uint64 max_age) { | 1038 uint64_t max_age) { |
| 1039 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 1039 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 1040 | 1040 |
| 1041 EnsureCoreExists(); | 1041 EnsureCoreExists(); |
| 1042 uint32 id = GetNextRequestId(); | 1042 uint32_t id = GetNextRequestId(); |
| 1043 core_->ClearSiteData(id, site, flags, max_age); | 1043 core_->ClearSiteData(id, site, flags, max_age); |
| 1044 return id; | 1044 return id; |
| 1045 } | 1045 } |
| 1046 | 1046 |
| 1047 uint32 PepperFlashSettingsManager::GetNextRequestId() { | 1047 uint32_t PepperFlashSettingsManager::GetNextRequestId() { |
| 1048 return next_request_id_++; | 1048 return next_request_id_++; |
| 1049 } | 1049 } |
| 1050 | 1050 |
| 1051 void PepperFlashSettingsManager::EnsureCoreExists() { | 1051 void PepperFlashSettingsManager::EnsureCoreExists() { |
| 1052 if (!core_.get()) { | 1052 if (!core_.get()) { |
| 1053 core_ = new Core(weak_ptr_factory_.GetWeakPtr(), browser_context_); | 1053 core_ = new Core(weak_ptr_factory_.GetWeakPtr(), browser_context_); |
| 1054 core_->Initialize(); | 1054 core_->Initialize(); |
| 1055 } | 1055 } |
| 1056 } | 1056 } |
| 1057 | 1057 |
| 1058 void PepperFlashSettingsManager::OnError(Core* core) { | 1058 void PepperFlashSettingsManager::OnError(Core* core) { |
| 1059 DCHECK(core); | 1059 DCHECK(core); |
| 1060 if (core != core_.get()) | 1060 if (core != core_.get()) |
| 1061 return; | 1061 return; |
| 1062 | 1062 |
| 1063 core_->Detach(); | 1063 core_->Detach(); |
| 1064 core_ = NULL; | 1064 core_ = NULL; |
| 1065 } | 1065 } |
| OLD | NEW |