Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(67)

Side by Side Diff: chrome/common/extensions/api/file_browser_handlers/file_browser_handler.cc

Issue 1030133002: Move the check for fileBrowserHandler permission to FileBrowserHandler. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Addressed @yoz comment. Created 5 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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/api/file_browser_handlers/file_browser_handle r.h" 5 #include "chrome/common/extensions/api/file_browser_handlers/file_browser_handle r.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "base/strings/string_number_conversions.h" 8 #include "base/strings/string_number_conversions.h"
9 #include "base/strings/string_util.h" 9 #include "base/strings/string_util.h"
10 #include "base/strings/utf_string_conversions.h" 10 #include "base/strings/utf_string_conversions.h"
11 #include "base/values.h" 11 #include "base/values.h"
12 #include "chrome/common/extensions/extension_constants.h" 12 #include "chrome/common/extensions/extension_constants.h"
13 #include "extensions/common/error_utils.h" 13 #include "extensions/common/error_utils.h"
14 #include "extensions/common/manifest.h" 14 #include "extensions/common/manifest.h"
15 #include "extensions/common/manifest_constants.h" 15 #include "extensions/common/manifest_constants.h"
16 #include "extensions/common/manifest_handlers/permissions_parser.h"
17 #include "extensions/common/permissions/api_permission.h"
16 #include "extensions/common/url_pattern.h" 18 #include "extensions/common/url_pattern.h"
17 #include "url/url_constants.h" 19 #include "url/url_constants.h"
18 20
19 namespace keys = extensions::manifest_keys; 21 namespace keys = extensions::manifest_keys;
20 namespace errors = extensions::manifest_errors; 22 namespace errors = extensions::manifest_errors;
21 23
22 namespace { 24 namespace {
23 25
24 const char kReadAccessString[] = "read"; 26 const char kReadAccessString[] = "read";
25 const char kReadWriteAccessString[] = "read-write"; 27 const char kReadWriteAccessString[] = "read-write";
(...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after
108 } 110 }
109 111
110 bool FileBrowserHandler::HasCreateAccessPermission() const { 112 bool FileBrowserHandler::HasCreateAccessPermission() const {
111 DCHECK(!(file_access_permission_flags_ & kInvalidPermission)); 113 DCHECK(!(file_access_permission_flags_ & kInvalidPermission));
112 return (file_access_permission_flags_ & kCreatePermission) != 0; 114 return (file_access_permission_flags_ & kCreatePermission) != 0;
113 } 115 }
114 116
115 // static 117 // static
116 FileBrowserHandler::List* 118 FileBrowserHandler::List*
117 FileBrowserHandler::GetHandlers(const extensions::Extension* extension) { 119 FileBrowserHandler::GetHandlers(const extensions::Extension* extension) {
118 FileBrowserHandlerInfo* info = static_cast<FileBrowserHandlerInfo*>( 120 FileBrowserHandlerInfo* const info = static_cast<FileBrowserHandlerInfo*>(
119 extension->GetManifestData(keys::kFileBrowserHandlers)); 121 extension->GetManifestData(keys::kFileBrowserHandlers));
120 if (info) 122 if (!info)
121 return &info->file_browser_handlers; 123 return nullptr;
122 return NULL; 124
125 return &info->file_browser_handlers;
123 } 126 }
124 127
125 FileBrowserHandlerParser::FileBrowserHandlerParser() { 128 FileBrowserHandlerParser::FileBrowserHandlerParser() {
126 } 129 }
127 130
128 FileBrowserHandlerParser::~FileBrowserHandlerParser() { 131 FileBrowserHandlerParser::~FileBrowserHandlerParser() {
129 } 132 }
130 133
131 namespace { 134 namespace {
132 135
(...skipping 128 matching lines...) Expand 10 before | Expand all | Expand 10 after
261 return false; // Failed to parse file browser action definition. 264 return false; // Failed to parse file browser action definition.
262 result->push_back(linked_ptr<FileBrowserHandler>(action.release())); 265 result->push_back(linked_ptr<FileBrowserHandler>(action.release()));
263 } 266 }
264 return true; 267 return true;
265 } 268 }
266 269
267 } // namespace 270 } // namespace
268 271
269 bool FileBrowserHandlerParser::Parse(extensions::Extension* extension, 272 bool FileBrowserHandlerParser::Parse(extensions::Extension* extension,
270 base::string16* error) { 273 base::string16* error) {
274 // If the permission is missing, then skip parsing the list of handlers.
Yoyo Zhou 2015/03/26 01:31:32 I think it would be helpful to add an install warn
mtomasz 2015/03/26 01:35:32 Agreed. Let me do it in a separate CL, as this one
275 if (!extensions::PermissionsParser::HasAPIPermission(
276 extension, extensions::APIPermission::ID::kFileBrowserHandler)) {
277 return true;
278 }
279
271 const base::ListValue* file_browser_handlers_value = NULL; 280 const base::ListValue* file_browser_handlers_value = NULL;
272 if (!extension->manifest()->GetList(keys::kFileBrowserHandlers, 281 if (!extension->manifest()->GetList(keys::kFileBrowserHandlers,
273 &file_browser_handlers_value)) { 282 &file_browser_handlers_value)) {
274 *error = base::ASCIIToUTF16(errors::kInvalidFileBrowserHandler); 283 *error = base::ASCIIToUTF16(errors::kInvalidFileBrowserHandler);
275 return false; 284 return false;
276 } 285 }
286
277 scoped_ptr<FileBrowserHandlerInfo> info(new FileBrowserHandlerInfo); 287 scoped_ptr<FileBrowserHandlerInfo> info(new FileBrowserHandlerInfo);
278 if (!LoadFileBrowserHandlers(extension->id(), 288 if (!LoadFileBrowserHandlers(extension->id(),
279 file_browser_handlers_value, 289 file_browser_handlers_value,
280 &info->file_browser_handlers, 290 &info->file_browser_handlers,
281 error)) { 291 error)) {
282 return false; // Failed to parse file browser actions definition. 292 return false; // Failed to parse file browser actions definition.
283 } 293 }
284 294
285 extension->SetManifestData(keys::kFileBrowserHandlers, info.release()); 295 extension->SetManifestData(keys::kFileBrowserHandlers, info.release());
286 return true; 296 return true;
287 } 297 }
288 298
289 const std::vector<std::string> FileBrowserHandlerParser::Keys() const { 299 const std::vector<std::string> FileBrowserHandlerParser::Keys() const {
290 return SingleKey(keys::kFileBrowserHandlers); 300 return SingleKey(keys::kFileBrowserHandlers);
291 } 301 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698