| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/common/extensions/manifest_handlers/automation.h" | 5 #include "chrome/common/extensions/manifest_handlers/automation.h" |
| 6 | 6 |
| 7 #include <memory> |
| 7 #include <utility> | 8 #include <utility> |
| 8 | 9 |
| 10 #include "base/memory/ptr_util.h" |
| 9 #include "base/strings/utf_string_conversions.h" | 11 #include "base/strings/utf_string_conversions.h" |
| 10 #include "chrome/common/extensions/api/manifest_types.h" | 12 #include "chrome/common/extensions/api/manifest_types.h" |
| 11 #include "chrome/grit/generated_resources.h" | 13 #include "chrome/grit/generated_resources.h" |
| 12 #include "extensions/common/error_utils.h" | 14 #include "extensions/common/error_utils.h" |
| 13 #include "extensions/common/extensions_client.h" | 15 #include "extensions/common/extensions_client.h" |
| 14 #include "extensions/common/manifest_constants.h" | 16 #include "extensions/common/manifest_constants.h" |
| 15 #include "extensions/common/permissions/api_permission_set.h" | 17 #include "extensions/common/permissions/api_permission_set.h" |
| 16 #include "extensions/common/permissions/manifest_permission.h" | 18 #include "extensions/common/permissions/manifest_permission.h" |
| 17 #include "extensions/common/permissions/permission_message_util.h" | 19 #include "extensions/common/permissions/permission_message_util.h" |
| 18 #include "extensions/common/permissions/permissions_data.h" | 20 #include "extensions/common/permissions/permissions_data.h" |
| (...skipping 15 matching lines...) Expand all Loading... |
| 34 const char kErrorNoMatchesProvided[] = "No valid match patterns provided."; | 36 const char kErrorNoMatchesProvided[] = "No valid match patterns provided."; |
| 35 } | 37 } |
| 36 | 38 |
| 37 namespace errors = manifest_errors; | 39 namespace errors = manifest_errors; |
| 38 namespace keys = extensions::manifest_keys; | 40 namespace keys = extensions::manifest_keys; |
| 39 using api::manifest_types::Automation; | 41 using api::manifest_types::Automation; |
| 40 | 42 |
| 41 class AutomationManifestPermission : public ManifestPermission { | 43 class AutomationManifestPermission : public ManifestPermission { |
| 42 public: | 44 public: |
| 43 explicit AutomationManifestPermission( | 45 explicit AutomationManifestPermission( |
| 44 scoped_ptr<const AutomationInfo> automation_info) | 46 std::unique_ptr<const AutomationInfo> automation_info) |
| 45 : automation_info_(std::move(automation_info)) {} | 47 : automation_info_(std::move(automation_info)) {} |
| 46 | 48 |
| 47 // extensions::ManifestPermission overrides. | 49 // extensions::ManifestPermission overrides. |
| 48 std::string name() const override; | 50 std::string name() const override; |
| 49 | 51 |
| 50 std::string id() const override; | 52 std::string id() const override; |
| 51 | 53 |
| 52 PermissionIDSet GetPermissions() const override; | 54 PermissionIDSet GetPermissions() const override; |
| 53 | 55 |
| 54 bool FromValue(const base::Value* value) override; | 56 bool FromValue(const base::Value* value) override; |
| 55 | 57 |
| 56 scoped_ptr<base::Value> ToValue() const override; | 58 std::unique_ptr<base::Value> ToValue() const override; |
| 57 | 59 |
| 58 ManifestPermission* Diff(const ManifestPermission* rhs) const override; | 60 ManifestPermission* Diff(const ManifestPermission* rhs) const override; |
| 59 | 61 |
| 60 ManifestPermission* Union(const ManifestPermission* rhs) const override; | 62 ManifestPermission* Union(const ManifestPermission* rhs) const override; |
| 61 | 63 |
| 62 ManifestPermission* Intersect(const ManifestPermission* rhs) const override; | 64 ManifestPermission* Intersect(const ManifestPermission* rhs) const override; |
| 63 | 65 |
| 64 private: | 66 private: |
| 65 scoped_ptr<const AutomationInfo> automation_info_; | 67 std::unique_ptr<const AutomationInfo> automation_info_; |
| 66 }; | 68 }; |
| 67 | 69 |
| 68 std::string AutomationManifestPermission::name() const { | 70 std::string AutomationManifestPermission::name() const { |
| 69 return keys::kAutomation; | 71 return keys::kAutomation; |
| 70 } | 72 } |
| 71 | 73 |
| 72 std::string AutomationManifestPermission::id() const { | 74 std::string AutomationManifestPermission::id() const { |
| 73 return keys::kAutomation; | 75 return keys::kAutomation; |
| 74 } | 76 } |
| 75 | 77 |
| (...skipping 25 matching lines...) Expand all Loading... |
| 101 } | 103 } |
| 102 | 104 |
| 103 bool AutomationManifestPermission::FromValue(const base::Value* value) { | 105 bool AutomationManifestPermission::FromValue(const base::Value* value) { |
| 104 base::string16 error; | 106 base::string16 error; |
| 105 automation_info_.reset(AutomationInfo::FromValue(*value, | 107 automation_info_.reset(AutomationInfo::FromValue(*value, |
| 106 NULL /* install_warnings */, | 108 NULL /* install_warnings */, |
| 107 &error).release()); | 109 &error).release()); |
| 108 return error.empty(); | 110 return error.empty(); |
| 109 } | 111 } |
| 110 | 112 |
| 111 scoped_ptr<base::Value> AutomationManifestPermission::ToValue() const { | 113 std::unique_ptr<base::Value> AutomationManifestPermission::ToValue() const { |
| 112 return AutomationInfo::ToValue(*automation_info_); | 114 return AutomationInfo::ToValue(*automation_info_); |
| 113 } | 115 } |
| 114 | 116 |
| 115 ManifestPermission* AutomationManifestPermission::Diff( | 117 ManifestPermission* AutomationManifestPermission::Diff( |
| 116 const ManifestPermission* rhs) const { | 118 const ManifestPermission* rhs) const { |
| 117 const AutomationManifestPermission* other = | 119 const AutomationManifestPermission* other = |
| 118 static_cast<const AutomationManifestPermission*>(rhs); | 120 static_cast<const AutomationManifestPermission*>(rhs); |
| 119 | 121 |
| 120 bool desktop = automation_info_->desktop && !other->automation_info_->desktop; | 122 bool desktop = automation_info_->desktop && !other->automation_info_->desktop; |
| 121 bool interact = | 123 bool interact = |
| 122 automation_info_->interact && !other->automation_info_->interact; | 124 automation_info_->interact && !other->automation_info_->interact; |
| 123 URLPatternSet matches = URLPatternSet::CreateDifference( | 125 URLPatternSet matches = URLPatternSet::CreateDifference( |
| 124 automation_info_->matches, other->automation_info_->matches); | 126 automation_info_->matches, other->automation_info_->matches); |
| 125 return new AutomationManifestPermission( | 127 return new AutomationManifestPermission( |
| 126 make_scoped_ptr(new const AutomationInfo(desktop, matches, interact))); | 128 base::WrapUnique(new const AutomationInfo(desktop, matches, interact))); |
| 127 } | 129 } |
| 128 | 130 |
| 129 ManifestPermission* AutomationManifestPermission::Union( | 131 ManifestPermission* AutomationManifestPermission::Union( |
| 130 const ManifestPermission* rhs) const { | 132 const ManifestPermission* rhs) const { |
| 131 const AutomationManifestPermission* other = | 133 const AutomationManifestPermission* other = |
| 132 static_cast<const AutomationManifestPermission*>(rhs); | 134 static_cast<const AutomationManifestPermission*>(rhs); |
| 133 | 135 |
| 134 bool desktop = automation_info_->desktop || other->automation_info_->desktop; | 136 bool desktop = automation_info_->desktop || other->automation_info_->desktop; |
| 135 bool interact = | 137 bool interact = |
| 136 automation_info_->interact || other->automation_info_->interact; | 138 automation_info_->interact || other->automation_info_->interact; |
| 137 URLPatternSet matches = URLPatternSet::CreateUnion( | 139 URLPatternSet matches = URLPatternSet::CreateUnion( |
| 138 automation_info_->matches, other->automation_info_->matches); | 140 automation_info_->matches, other->automation_info_->matches); |
| 139 return new AutomationManifestPermission( | 141 return new AutomationManifestPermission( |
| 140 make_scoped_ptr(new const AutomationInfo(desktop, matches, interact))); | 142 base::WrapUnique(new const AutomationInfo(desktop, matches, interact))); |
| 141 } | 143 } |
| 142 | 144 |
| 143 ManifestPermission* AutomationManifestPermission::Intersect( | 145 ManifestPermission* AutomationManifestPermission::Intersect( |
| 144 const ManifestPermission* rhs) const { | 146 const ManifestPermission* rhs) const { |
| 145 const AutomationManifestPermission* other = | 147 const AutomationManifestPermission* other = |
| 146 static_cast<const AutomationManifestPermission*>(rhs); | 148 static_cast<const AutomationManifestPermission*>(rhs); |
| 147 | 149 |
| 148 bool desktop = automation_info_->desktop && other->automation_info_->desktop; | 150 bool desktop = automation_info_->desktop && other->automation_info_->desktop; |
| 149 bool interact = | 151 bool interact = |
| 150 automation_info_->interact && other->automation_info_->interact; | 152 automation_info_->interact && other->automation_info_->interact; |
| 151 URLPatternSet matches = URLPatternSet::CreateIntersection( | 153 URLPatternSet matches = URLPatternSet::CreateIntersection( |
| 152 automation_info_->matches, other->automation_info_->matches); | 154 automation_info_->matches, other->automation_info_->matches); |
| 153 return new AutomationManifestPermission( | 155 return new AutomationManifestPermission( |
| 154 make_scoped_ptr(new const AutomationInfo(desktop, matches, interact))); | 156 base::WrapUnique(new const AutomationInfo(desktop, matches, interact))); |
| 155 } | 157 } |
| 156 | 158 |
| 157 AutomationHandler::AutomationHandler() { | 159 AutomationHandler::AutomationHandler() { |
| 158 } | 160 } |
| 159 | 161 |
| 160 AutomationHandler::~AutomationHandler() { | 162 AutomationHandler::~AutomationHandler() { |
| 161 } | 163 } |
| 162 | 164 |
| 163 bool AutomationHandler::Parse(Extension* extension, base::string16* error) { | 165 bool AutomationHandler::Parse(Extension* extension, base::string16* error) { |
| 164 const base::Value* automation = NULL; | 166 const base::Value* automation = NULL; |
| 165 CHECK(extension->manifest()->Get(keys::kAutomation, &automation)); | 167 CHECK(extension->manifest()->Get(keys::kAutomation, &automation)); |
| 166 std::vector<InstallWarning> install_warnings; | 168 std::vector<InstallWarning> install_warnings; |
| 167 scoped_ptr<AutomationInfo> info = | 169 std::unique_ptr<AutomationInfo> info = |
| 168 AutomationInfo::FromValue(*automation, &install_warnings, error); | 170 AutomationInfo::FromValue(*automation, &install_warnings, error); |
| 169 if (!error->empty()) | 171 if (!error->empty()) |
| 170 return false; | 172 return false; |
| 171 | 173 |
| 172 extension->AddInstallWarnings(install_warnings); | 174 extension->AddInstallWarnings(install_warnings); |
| 173 | 175 |
| 174 if (!info) | 176 if (!info) |
| 175 return true; | 177 return true; |
| 176 | 178 |
| 177 extension->SetManifestData(keys::kAutomation, info.release()); | 179 extension->SetManifestData(keys::kAutomation, info.release()); |
| 178 return true; | 180 return true; |
| 179 } | 181 } |
| 180 | 182 |
| 181 const std::vector<std::string> AutomationHandler::Keys() const { | 183 const std::vector<std::string> AutomationHandler::Keys() const { |
| 182 return SingleKey(keys::kAutomation); | 184 return SingleKey(keys::kAutomation); |
| 183 } | 185 } |
| 184 | 186 |
| 185 ManifestPermission* AutomationHandler::CreatePermission() { | 187 ManifestPermission* AutomationHandler::CreatePermission() { |
| 186 return new AutomationManifestPermission( | 188 return new AutomationManifestPermission( |
| 187 make_scoped_ptr(new const AutomationInfo)); | 189 base::WrapUnique(new const AutomationInfo)); |
| 188 } | 190 } |
| 189 | 191 |
| 190 ManifestPermission* AutomationHandler::CreateInitialRequiredPermission( | 192 ManifestPermission* AutomationHandler::CreateInitialRequiredPermission( |
| 191 const Extension* extension) { | 193 const Extension* extension) { |
| 192 const AutomationInfo* info = AutomationInfo::Get(extension); | 194 const AutomationInfo* info = AutomationInfo::Get(extension); |
| 193 if (info) { | 195 if (info) { |
| 194 return new AutomationManifestPermission( | 196 return new AutomationManifestPermission( |
| 195 make_scoped_ptr(new const AutomationInfo( | 197 base::WrapUnique(new const AutomationInfo(info->desktop, info->matches, |
| 196 info->desktop, info->matches, info->interact))); | 198 info->interact))); |
| 197 } | 199 } |
| 198 return NULL; | 200 return NULL; |
| 199 } | 201 } |
| 200 | 202 |
| 201 // static | 203 // static |
| 202 const AutomationInfo* AutomationInfo::Get(const Extension* extension) { | 204 const AutomationInfo* AutomationInfo::Get(const Extension* extension) { |
| 203 return static_cast<AutomationInfo*>( | 205 return static_cast<AutomationInfo*>( |
| 204 extension->GetManifestData(keys::kAutomation)); | 206 extension->GetManifestData(keys::kAutomation)); |
| 205 } | 207 } |
| 206 | 208 |
| 207 // static | 209 // static |
| 208 scoped_ptr<AutomationInfo> AutomationInfo::FromValue( | 210 std::unique_ptr<AutomationInfo> AutomationInfo::FromValue( |
| 209 const base::Value& value, | 211 const base::Value& value, |
| 210 std::vector<InstallWarning>* install_warnings, | 212 std::vector<InstallWarning>* install_warnings, |
| 211 base::string16* error) { | 213 base::string16* error) { |
| 212 scoped_ptr<Automation> automation = Automation::FromValue(value, error); | 214 std::unique_ptr<Automation> automation = Automation::FromValue(value, error); |
| 213 if (!automation) | 215 if (!automation) |
| 214 return scoped_ptr<AutomationInfo>(); | 216 return std::unique_ptr<AutomationInfo>(); |
| 215 | 217 |
| 216 if (automation->as_boolean) { | 218 if (automation->as_boolean) { |
| 217 if (*automation->as_boolean) | 219 if (*automation->as_boolean) |
| 218 return make_scoped_ptr(new AutomationInfo()); | 220 return base::WrapUnique(new AutomationInfo()); |
| 219 return scoped_ptr<AutomationInfo>(); | 221 return std::unique_ptr<AutomationInfo>(); |
| 220 } | 222 } |
| 221 const Automation::Object& automation_object = *automation->as_object; | 223 const Automation::Object& automation_object = *automation->as_object; |
| 222 | 224 |
| 223 bool desktop = false; | 225 bool desktop = false; |
| 224 bool interact = false; | 226 bool interact = false; |
| 225 if (automation_object.desktop && *automation_object.desktop) { | 227 if (automation_object.desktop && *automation_object.desktop) { |
| 226 desktop = true; | 228 desktop = true; |
| 227 interact = true; | 229 interact = true; |
| 228 if (automation_object.interact && !*automation_object.interact) { | 230 if (automation_object.interact && !*automation_object.interact) { |
| 229 // TODO(aboxhall): Do we want to allow this? | 231 // TODO(aboxhall): Do we want to allow this? |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 265 | 267 |
| 266 matches.AddPattern(pattern); | 268 matches.AddPattern(pattern); |
| 267 } | 269 } |
| 268 } | 270 } |
| 269 } | 271 } |
| 270 if (specified_matches && matches.is_empty()) { | 272 if (specified_matches && matches.is_empty()) { |
| 271 install_warnings->push_back( | 273 install_warnings->push_back( |
| 272 InstallWarning(automation_errors::kErrorNoMatchesProvided)); | 274 InstallWarning(automation_errors::kErrorNoMatchesProvided)); |
| 273 } | 275 } |
| 274 | 276 |
| 275 return make_scoped_ptr(new AutomationInfo(desktop, matches, interact)); | 277 return base::WrapUnique(new AutomationInfo(desktop, matches, interact)); |
| 276 } | 278 } |
| 277 | 279 |
| 278 // static | 280 // static |
| 279 scoped_ptr<base::Value> AutomationInfo::ToValue(const AutomationInfo& info) { | 281 std::unique_ptr<base::Value> AutomationInfo::ToValue( |
| 282 const AutomationInfo& info) { |
| 280 return AsManifestType(info)->ToValue(); | 283 return AsManifestType(info)->ToValue(); |
| 281 } | 284 } |
| 282 | 285 |
| 283 // static | 286 // static |
| 284 scoped_ptr<Automation> AutomationInfo::AsManifestType( | 287 std::unique_ptr<Automation> AutomationInfo::AsManifestType( |
| 285 const AutomationInfo& info) { | 288 const AutomationInfo& info) { |
| 286 scoped_ptr<Automation> automation(new Automation); | 289 std::unique_ptr<Automation> automation(new Automation); |
| 287 if (!info.desktop && !info.interact && info.matches.size() == 0) { | 290 if (!info.desktop && !info.interact && info.matches.size() == 0) { |
| 288 automation->as_boolean.reset(new bool(true)); | 291 automation->as_boolean.reset(new bool(true)); |
| 289 return automation; | 292 return automation; |
| 290 } | 293 } |
| 291 | 294 |
| 292 Automation::Object* as_object = new Automation::Object; | 295 Automation::Object* as_object = new Automation::Object; |
| 293 as_object->desktop.reset(new bool(info.desktop)); | 296 as_object->desktop.reset(new bool(info.desktop)); |
| 294 as_object->interact.reset(new bool(info.interact)); | 297 as_object->interact.reset(new bool(info.interact)); |
| 295 if (info.matches.size() > 0) { | 298 if (info.matches.size() > 0) { |
| 296 as_object->matches.reset(info.matches.ToStringVector().release()); | 299 as_object->matches.reset(info.matches.ToStringVector().release()); |
| 297 } | 300 } |
| 298 automation->as_object.reset(as_object); | 301 automation->as_object.reset(as_object); |
| 299 return automation; | 302 return automation; |
| 300 } | 303 } |
| 301 | 304 |
| 302 AutomationInfo::AutomationInfo() : desktop(false), interact(false) { | 305 AutomationInfo::AutomationInfo() : desktop(false), interact(false) { |
| 303 } | 306 } |
| 304 | 307 |
| 305 AutomationInfo::AutomationInfo(bool desktop, | 308 AutomationInfo::AutomationInfo(bool desktop, |
| 306 const URLPatternSet matches, | 309 const URLPatternSet matches, |
| 307 bool interact) | 310 bool interact) |
| 308 : desktop(desktop), matches(matches), interact(interact) { | 311 : desktop(desktop), matches(matches), interact(interact) { |
| 309 } | 312 } |
| 310 | 313 |
| 311 AutomationInfo::~AutomationInfo() { | 314 AutomationInfo::~AutomationInfo() { |
| 312 } | 315 } |
| 313 | 316 |
| 314 } // namespace extensions | 317 } // namespace extensions |
| OLD | NEW |