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> tab_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 CHECK(tab_permissions); |
| 547 if (tab_permissions->explicit_hosts().ContainsPattern(all_urls)) |
| 548 return true; |
| 549 |
| 550 if (tab_id >= 0 && |
| 551 HasAPIPermission(extension, APIPermission::kActiveTab)) { |
| 552 if (GetTabSpecificPermissions(extension, tab_id)) |
548 return true; | 553 return true; |
549 } | 554 if (error) |
| 555 *error = errors::kActiveTabPermissionNotGranted; |
| 556 return false; |
550 } | 557 } |
551 | 558 |
552 if (HasHostPermission(extension, page_url) || | 559 if (error) |
553 page_url.GetOrigin() == extension->url()) { | 560 *error = errors::kAllURLOrActiveTabNeeded; |
554 return true; | |
555 } | |
556 | |
557 if (error) { | |
558 *error = ErrorUtils::FormatErrorMessage(errors::kCannotAccessPage, | |
559 page_url.spec()); | |
560 } | |
561 return false; | 561 return false; |
562 } | 562 } |
563 | 563 |
564 bool PermissionsData::ParsePermissions(Extension* extension, | 564 bool PermissionsData::ParsePermissions(Extension* extension, |
565 base::string16* error) { | 565 base::string16* error) { |
566 initial_required_permissions_.reset(new InitialPermissions); | 566 initial_required_permissions_.reset(new InitialPermissions); |
567 if (!ParseHelper(extension, | 567 if (!ParseHelper(extension, |
568 keys::kPermissions, | 568 keys::kPermissions, |
569 &initial_required_permissions_->api_permissions, | 569 &initial_required_permissions_->api_permissions, |
570 &initial_required_permissions_->host_permissions, | 570 &initial_required_permissions_->host_permissions, |
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
618 initial_optional_permissions_->api_permissions, | 618 initial_optional_permissions_->api_permissions, |
619 initial_optional_permissions_->manifest_permissions, | 619 initial_optional_permissions_->manifest_permissions, |
620 initial_optional_permissions_->host_permissions, | 620 initial_optional_permissions_->host_permissions, |
621 URLPatternSet()); | 621 URLPatternSet()); |
622 | 622 |
623 initial_required_permissions_.reset(); | 623 initial_required_permissions_.reset(); |
624 initial_optional_permissions_.reset(); | 624 initial_optional_permissions_.reset(); |
625 } | 625 } |
626 | 626 |
627 } // namespace extensions | 627 } // namespace extensions |
OLD | NEW |