| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/permissions/chooser_context_base.h" | 5 #include "chrome/browser/permissions/chooser_context_base.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/memory/ptr_util.h" | 9 #include "base/memory/ptr_util.h" |
| 10 #include "chrome/browser/content_settings/host_content_settings_map_factory.h" | 10 #include "chrome/browser/content_settings/host_content_settings_map_factory.h" |
| (...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 51 return results; | 51 return results; |
| 52 | 52 |
| 53 std::unique_ptr<base::ListValue> object_list = | 53 std::unique_ptr<base::ListValue> object_list = |
| 54 base::ListValue::From(std::move(objects)); | 54 base::ListValue::From(std::move(objects)); |
| 55 if (!object_list) | 55 if (!object_list) |
| 56 return results; | 56 return results; |
| 57 | 57 |
| 58 for (auto& object : *object_list) { | 58 for (auto& object : *object_list) { |
| 59 // Steal ownership of |object| from |object_list|. | 59 // Steal ownership of |object| from |object_list|. |
| 60 std::unique_ptr<base::DictionaryValue> object_dict = | 60 std::unique_ptr<base::DictionaryValue> object_dict = |
| 61 base::DictionaryValue::From(std::move(object)); | 61 base::DictionaryValue::From( |
| 62 base::MakeUnique<base::Value>(std::move(object))); |
| 62 if (object_dict && IsValidObject(*object_dict)) | 63 if (object_dict && IsValidObject(*object_dict)) |
| 63 results.push_back(std::move(object_dict)); | 64 results.push_back(std::move(object_dict)); |
| 64 } | 65 } |
| 65 return results; | 66 return results; |
| 66 } | 67 } |
| 67 | 68 |
| 68 std::vector<std::unique_ptr<ChooserContextBase::Object>> | 69 std::vector<std::unique_ptr<ChooserContextBase::Object>> |
| 69 ChooserContextBase::GetAllGrantedObjects() { | 70 ChooserContextBase::GetAllGrantedObjects() { |
| 70 ContentSettingsForOneType content_settings; | 71 ContentSettingsForOneType content_settings; |
| 71 host_content_settings_map_->GetSettingsForOneType( | 72 host_content_settings_map_->GetSettingsForOneType( |
| 72 data_content_settings_type_, std::string(), &content_settings); | 73 data_content_settings_type_, std::string(), &content_settings); |
| 73 | 74 |
| 74 std::vector<std::unique_ptr<Object>> results; | 75 std::vector<std::unique_ptr<Object>> results; |
| 75 for (const ContentSettingPatternSource& content_setting : content_settings) { | 76 for (const ContentSettingPatternSource& content_setting : content_settings) { |
| 76 GURL requesting_origin(content_setting.primary_pattern.ToString()); | 77 GURL requesting_origin(content_setting.primary_pattern.ToString()); |
| 77 GURL embedding_origin(content_setting.secondary_pattern.ToString()); | 78 GURL embedding_origin(content_setting.secondary_pattern.ToString()); |
| 78 if (!requesting_origin.is_valid() || !embedding_origin.is_valid()) | 79 if (!requesting_origin.is_valid() || !embedding_origin.is_valid()) |
| 79 continue; | 80 continue; |
| 80 | 81 |
| 81 std::unique_ptr<base::DictionaryValue> setting = | 82 std::unique_ptr<base::DictionaryValue> setting = |
| 82 GetWebsiteSetting(requesting_origin, embedding_origin); | 83 GetWebsiteSetting(requesting_origin, embedding_origin); |
| 83 base::ListValue* object_list; | 84 base::ListValue* object_list; |
| 84 if (!setting->GetList(kObjectListKey, &object_list)) | 85 if (!setting->GetList(kObjectListKey, &object_list)) |
| 85 continue; | 86 continue; |
| 86 | 87 |
| 87 for (const auto& object : *object_list) { | 88 for (auto& object : *object_list) { |
| 88 base::DictionaryValue* object_dict; | 89 base::DictionaryValue* object_dict; |
| 89 if (!object->GetAsDictionary(&object_dict) || | 90 if (!object.GetAsDictionary(&object_dict) || |
| 90 !IsValidObject(*object_dict)) { | 91 !IsValidObject(*object_dict)) { |
| 91 continue; | 92 continue; |
| 92 } | 93 } |
| 93 | 94 |
| 94 results.push_back(base::MakeUnique<Object>( | 95 results.push_back(base::MakeUnique<Object>( |
| 95 requesting_origin, embedding_origin, object_dict, | 96 requesting_origin, embedding_origin, object_dict, |
| 96 content_setting.source, content_setting.incognito)); | 97 content_setting.source, content_setting.incognito)); |
| 97 } | 98 } |
| 98 } | 99 } |
| 99 | 100 |
| (...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 148 return value; | 149 return value; |
| 149 } | 150 } |
| 150 | 151 |
| 151 void ChooserContextBase::SetWebsiteSetting(const GURL& requesting_origin, | 152 void ChooserContextBase::SetWebsiteSetting(const GURL& requesting_origin, |
| 152 const GURL& embedding_origin, | 153 const GURL& embedding_origin, |
| 153 std::unique_ptr<base::Value> value) { | 154 std::unique_ptr<base::Value> value) { |
| 154 host_content_settings_map_->SetWebsiteSettingDefaultScope( | 155 host_content_settings_map_->SetWebsiteSettingDefaultScope( |
| 155 requesting_origin, embedding_origin, data_content_settings_type_, | 156 requesting_origin, embedding_origin, data_content_settings_type_, |
| 156 std::string(), std::move(value)); | 157 std::string(), std::move(value)); |
| 157 } | 158 } |
| OLD | NEW |