| OLD | NEW |
| 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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/policy/device_management_policy_provider.h" | 5 #include "chrome/browser/policy/device_management_policy_provider.h" |
| 6 | 6 |
| 7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
| 8 #include "base/file_util.h" | 8 #include "base/file_util.h" |
| 9 #include "base/path_service.h" | 9 #include "base/path_service.h" |
| 10 #include "base/task.h" | 10 #include "base/task.h" |
| 11 #include "base/time.h" | 11 #include "base/time.h" |
| 12 #include "chrome/browser/browser_thread.h" | 12 #include "chrome/browser/browser_thread.h" |
| 13 #include "chrome/browser/profile.h" |
| 13 #include "chrome/browser/policy/device_management_backend.h" | 14 #include "chrome/browser/policy/device_management_backend.h" |
| 14 #include "chrome/browser/policy/device_management_policy_cache.h" | 15 #include "chrome/browser/policy/device_management_policy_cache.h" |
| 15 #include "chrome/browser/policy/device_token_fetcher.h" | 16 #include "chrome/browser/policy/device_token_fetcher.h" |
| 16 #include "chrome/common/chrome_paths.h" | 17 #include "chrome/common/chrome_paths.h" |
| 17 #include "chrome/common/chrome_switches.h" | 18 #include "chrome/common/chrome_switches.h" |
| 18 #include "chrome/common/notification_service.h" | 19 #include "chrome/common/notification_service.h" |
| 19 #include "chrome/common/notification_type.h" | 20 #include "chrome/common/notification_type.h" |
| 20 | 21 |
| 21 namespace policy { | 22 namespace policy { |
| 22 | 23 |
| (...skipping 21 matching lines...) Expand all Loading... |
| 44 provider->InitializeAfterIOThreadExists(); | 45 provider->InitializeAfterIOThreadExists(); |
| 45 } | 46 } |
| 46 | 47 |
| 47 private: | 48 private: |
| 48 base::WeakPtr<DeviceManagementPolicyProvider> provider_; | 49 base::WeakPtr<DeviceManagementPolicyProvider> provider_; |
| 49 }; | 50 }; |
| 50 | 51 |
| 51 DeviceManagementPolicyProvider::DeviceManagementPolicyProvider( | 52 DeviceManagementPolicyProvider::DeviceManagementPolicyProvider( |
| 52 const ConfigurationPolicyProvider::PolicyDefinitionList* policy_list, | 53 const ConfigurationPolicyProvider::PolicyDefinitionList* policy_list, |
| 53 DeviceManagementBackend* backend, | 54 DeviceManagementBackend* backend, |
| 54 TokenService* token_service, | 55 Profile* profile) |
| 55 const FilePath& storage_dir) | |
| 56 : ConfigurationPolicyProvider(policy_list), | 56 : ConfigurationPolicyProvider(policy_list), |
| 57 backend_(backend), | 57 backend_(backend), |
| 58 token_service_(token_service), | 58 profile_(profile), |
| 59 storage_dir_(GetOrCreateDeviceManagementDir(storage_dir)), | 59 storage_dir_(GetOrCreateDeviceManagementDir(profile_->GetPath())), |
| 60 policy_request_pending_(false) { | 60 policy_request_pending_(false) { |
| 61 Initialize(); | 61 Initialize(); |
| 62 } | 62 } |
| 63 |
| 64 DeviceManagementPolicyProvider::DeviceManagementPolicyProvider( |
| 65 const ConfigurationPolicyProvider::PolicyDefinitionList* policy_list, |
| 66 DeviceManagementBackend* backend, |
| 67 Profile* profile, |
| 68 DeviceTokenFetcher* token_fetcher) |
| 69 : ConfigurationPolicyProvider(policy_list), |
| 70 backend_(backend), |
| 71 profile_(profile), |
| 72 token_fetcher_(token_fetcher), |
| 73 storage_dir_(GetOrCreateDeviceManagementDir(profile_->GetPath())), |
| 74 policy_request_pending_(false) { |
| 75 Initialize(); |
| 76 } |
| 63 | 77 |
| 64 DeviceManagementPolicyProvider::~DeviceManagementPolicyProvider() {} | 78 DeviceManagementPolicyProvider::~DeviceManagementPolicyProvider() {} |
| 65 | 79 |
| 66 bool DeviceManagementPolicyProvider::Provide( | 80 bool DeviceManagementPolicyProvider::Provide( |
| 67 ConfigurationPolicyStoreInterface* policy_store) { | 81 ConfigurationPolicyStoreInterface* policy_store) { |
| 68 scoped_ptr<DictionaryValue> policies(cache_->GetPolicy()); | 82 scoped_ptr<DictionaryValue> policies(cache_->GetPolicy()); |
| 69 DecodePolicyValueTree(policies.get(), policy_store); | 83 DecodePolicyValueTree(policies.get(), policy_store); |
| 70 return true; | 84 return true; |
| 71 } | 85 } |
| 72 | 86 |
| (...skipping 21 matching lines...) Expand all Loading... |
| 94 | 108 |
| 95 void DeviceManagementPolicyProvider::OnError( | 109 void DeviceManagementPolicyProvider::OnError( |
| 96 DeviceManagementBackend::ErrorCode code) { | 110 DeviceManagementBackend::ErrorCode code) { |
| 97 LOG(WARNING) << "could not provide policy from the device manager (error = " | 111 LOG(WARNING) << "could not provide policy from the device manager (error = " |
| 98 << code << ")"; | 112 << code << ")"; |
| 99 policy_request_pending_ = false; | 113 policy_request_pending_ = false; |
| 100 // TODO(danno): do something sensible in the error case, perhaps retry later? | 114 // TODO(danno): do something sensible in the error case, perhaps retry later? |
| 101 } | 115 } |
| 102 | 116 |
| 103 void DeviceManagementPolicyProvider::Shutdown() { | 117 void DeviceManagementPolicyProvider::Shutdown() { |
| 104 token_service_ = NULL; | 118 profile_ = NULL; |
| 105 if (token_fetcher_) | 119 if (token_fetcher_) |
| 106 token_fetcher_->Shutdown(); | 120 token_fetcher_->Shutdown(); |
| 107 } | 121 } |
| 108 | 122 |
| 109 void DeviceManagementPolicyProvider::Initialize() { | 123 void DeviceManagementPolicyProvider::Initialize() { |
| 110 registrar_.Add(this, | 124 registrar_.Add(this, |
| 111 NotificationType::DEVICE_TOKEN_AVAILABLE, | 125 NotificationType::DEVICE_TOKEN_AVAILABLE, |
| 112 NotificationService::AllSources()); | 126 NotificationService::AllSources()); |
| 113 | 127 |
| 114 const FilePath policy_path = storage_dir_.Append( | 128 const FilePath policy_path = storage_dir_.Append( |
| 115 FILE_PATH_LITERAL("Policy")); | 129 FILE_PATH_LITERAL("Policy")); |
| 116 cache_.reset(new DeviceManagementPolicyCache(policy_path)); | 130 cache_.reset(new DeviceManagementPolicyCache(policy_path)); |
| 117 cache_->LoadPolicyFromFile(); | 131 cache_->LoadPolicyFromFile(); |
| 118 | 132 |
| 119 // Defer initialization that requires the IOThread until after the IOThread | 133 // Defer initialization that requires the IOThread until after the IOThread |
| 120 // has been initialized. | 134 // has been initialized. |
| 121 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, | 135 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, |
| 122 new InitializeAfterIOThreadExistsTask(AsWeakPtr())); | 136 new InitializeAfterIOThreadExistsTask(AsWeakPtr())); |
| 123 } | 137 } |
| 124 | 138 |
| 125 void DeviceManagementPolicyProvider::InitializeAfterIOThreadExists() { | 139 void DeviceManagementPolicyProvider::InitializeAfterIOThreadExists() { |
| 126 const FilePath token_path = storage_dir_.Append( | 140 const FilePath token_path = storage_dir_.Append( |
| 127 FILE_PATH_LITERAL("Token")); | 141 FILE_PATH_LITERAL("Token")); |
| 128 if (token_service_) { | 142 if (profile_) { |
| 129 token_fetcher_ = | 143 if (!token_fetcher_) { |
| 130 new DeviceTokenFetcher(backend_.get(), token_service_, token_path); | 144 token_fetcher_ = |
| 145 new DeviceTokenFetcher(backend_.get(), profile_, token_path); |
| 146 } |
| 131 token_fetcher_->StartFetching(); | 147 token_fetcher_->StartFetching(); |
| 132 } | 148 } |
| 133 } | 149 } |
| 134 | 150 |
| 135 void DeviceManagementPolicyProvider::SendPolicyRequest() { | 151 void DeviceManagementPolicyProvider::SendPolicyRequest() { |
| 136 if (!policy_request_pending_) { | 152 if (!policy_request_pending_) { |
| 137 em::DevicePolicyRequest policy_request; | 153 em::DevicePolicyRequest policy_request; |
| 138 policy_request.set_policy_scope(kChromePolicyScope); | 154 policy_request.set_policy_scope(kChromePolicyScope); |
| 139 em::DevicePolicySettingRequest* setting = | 155 em::DevicePolicySettingRequest* setting = |
| 140 policy_request.add_setting_request(); | 156 policy_request.add_setting_request(); |
| (...skipping 27 matching lines...) Expand all Loading... |
| 168 const FilePath device_management_dir = user_data_dir.Append( | 184 const FilePath device_management_dir = user_data_dir.Append( |
| 169 FILE_PATH_LITERAL("Device Management")); | 185 FILE_PATH_LITERAL("Device Management")); |
| 170 if (!file_util::DirectoryExists(device_management_dir)) { | 186 if (!file_util::DirectoryExists(device_management_dir)) { |
| 171 if (!file_util::CreateDirectory(device_management_dir)) | 187 if (!file_util::CreateDirectory(device_management_dir)) |
| 172 NOTREACHED(); | 188 NOTREACHED(); |
| 173 } | 189 } |
| 174 return device_management_dir; | 190 return device_management_dir; |
| 175 } | 191 } |
| 176 | 192 |
| 177 } // namespace policy | 193 } // namespace policy |
| OLD | NEW |