OLD | NEW |
---|---|
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 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 "extensions/common/permissions/permissions_data.h" | 5 #include "extensions/common/permissions/permissions_data.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/memory/scoped_ptr.h" | 8 #include "base/memory/scoped_ptr.h" |
9 #include "base/strings/string16.h" | 9 #include "base/strings/string16.h" |
10 #include "base/strings/string_number_conversions.h" | 10 #include "base/strings/string_number_conversions.h" |
(...skipping 519 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
530 | 530 |
531 const ExtensionsClient::ScriptingWhitelist& whitelist = | 531 const ExtensionsClient::ScriptingWhitelist& whitelist = |
532 ExtensionsClient::Get()->GetScriptingWhitelist(); | 532 ExtensionsClient::Get()->GetScriptingWhitelist(); |
533 | 533 |
534 return std::find(whitelist.begin(), whitelist.end(), extension->id()) != | 534 return std::find(whitelist.begin(), whitelist.end(), extension->id()) != |
535 whitelist.end(); | 535 whitelist.end(); |
536 } | 536 } |
537 | 537 |
538 // static | 538 // static |
539 bool PermissionsData::CanCaptureVisiblePage(const Extension* extension, | 539 bool PermissionsData::CanCaptureVisiblePage(const Extension* extension, |
540 const GURL& page_url, | |
541 int tab_id, | 540 int tab_id, |
542 std::string* error) { | 541 std::string* error) { |
543 if (tab_id >= 0) { | 542 scoped_refptr<const PermissionSet> active_permissions = |
544 scoped_refptr<const PermissionSet> tab_permissions = | 543 GetActivePermissions(extension); |
545 GetTabSpecificPermissions(extension, tab_id); | 544 const URLPattern all_urls(URLPattern::SCHEME_ALL, |
546 if (tab_permissions.get() && | 545 URLPattern::kAllUrlsPattern); |
547 tab_permissions->explicit_hosts().MatchesSecurityOrigin(page_url)) { | 546 if (active_permissions && |
not at google - send to devlin
2014/01/23 20:16:35
it's the tab-specific permissions that need null c
sadrul
2014/01/23 20:23:49
More likely I misunderstood. Fixed
| |
548 return true; | 547 active_permissions->explicit_hosts().ContainsPattern(all_urls)) { |
549 } | |
550 } | |
551 | |
552 if (HasHostPermission(extension, page_url) || | |
553 page_url.GetOrigin() == extension->url()) { | |
554 return true; | 548 return true; |
555 } | 549 } |
556 | 550 |
557 if (error) { | 551 if (tab_id >= 0 && |
558 *error = ErrorUtils::FormatErrorMessage(errors::kCannotAccessPage, | 552 HasAPIPermission(extension, APIPermission::kActiveTab)) { |
not at google - send to devlin
2014/01/23 20:16:35
I think this check is unnecessary. Just let the Ac
sadrul
2014/01/23 20:23:49
Done.
| |
559 page_url.spec()); | 553 scoped_refptr<const PermissionSet> tab_permissions = |
554 GetTabSpecificPermissions(extension, tab_id); | |
555 if (tab_permissions && | |
556 tab_permissions->HasAPIPermission(APIPermission::kTab)) { | |
557 return true; | |
558 } | |
559 if (error) | |
560 *error = errors::kActiveTabPermissionNotGranted; | |
561 return false; | |
560 } | 562 } |
563 | |
564 if (error) | |
565 *error = errors::kAllURLOrActiveTabNeeded; | |
561 return false; | 566 return false; |
562 } | 567 } |
563 | 568 |
564 bool PermissionsData::ParsePermissions(Extension* extension, | 569 bool PermissionsData::ParsePermissions(Extension* extension, |
565 base::string16* error) { | 570 base::string16* error) { |
566 initial_required_permissions_.reset(new InitialPermissions); | 571 initial_required_permissions_.reset(new InitialPermissions); |
567 if (!ParseHelper(extension, | 572 if (!ParseHelper(extension, |
568 keys::kPermissions, | 573 keys::kPermissions, |
569 &initial_required_permissions_->api_permissions, | 574 &initial_required_permissions_->api_permissions, |
570 &initial_required_permissions_->host_permissions, | 575 &initial_required_permissions_->host_permissions, |
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
606 initial_optional_permissions_->api_permissions, | 611 initial_optional_permissions_->api_permissions, |
607 initial_optional_permissions_->manifest_permissions, | 612 initial_optional_permissions_->manifest_permissions, |
608 initial_optional_permissions_->host_permissions, | 613 initial_optional_permissions_->host_permissions, |
609 URLPatternSet()); | 614 URLPatternSet()); |
610 | 615 |
611 initial_required_permissions_.reset(); | 616 initial_required_permissions_.reset(); |
612 initial_optional_permissions_.reset(); | 617 initial_optional_permissions_.reset(); |
613 } | 618 } |
614 | 619 |
615 } // namespace extensions | 620 } // namespace extensions |
OLD | NEW |