OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/extensions/api/management/management_api.h" | 5 #include "chrome/browser/extensions/api/management/management_api.h" |
6 | 6 |
7 #include <map> | 7 #include <map> |
8 #include <string> | 8 #include <string> |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
(...skipping 449 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
460 ManagementSetEnabledFunction::~ManagementSetEnabledFunction() { | 460 ManagementSetEnabledFunction::~ManagementSetEnabledFunction() { |
461 } | 461 } |
462 | 462 |
463 bool ManagementSetEnabledFunction::RunAsync() { | 463 bool ManagementSetEnabledFunction::RunAsync() { |
464 scoped_ptr<management::SetEnabled::Params> params( | 464 scoped_ptr<management::SetEnabled::Params> params( |
465 management::SetEnabled::Params::Create(*args_)); | 465 management::SetEnabled::Params::Create(*args_)); |
466 EXTENSION_FUNCTION_VALIDATE(params.get()); | 466 EXTENSION_FUNCTION_VALIDATE(params.get()); |
467 | 467 |
468 extension_id_ = params->id; | 468 extension_id_ = params->id; |
469 | 469 |
470 const Extension* extension = service()->GetInstalledExtension(extension_id_); | 470 const Extension* extension = |
| 471 ExtensionRegistry::Get(GetProfile()) |
| 472 ->GetExtensionById(extension_id_, ExtensionRegistry::EVERYTHING); |
471 if (!extension || extension->ShouldNotBeVisible()) { | 473 if (!extension || extension->ShouldNotBeVisible()) { |
472 error_ = ErrorUtils::FormatErrorMessage( | 474 error_ = ErrorUtils::FormatErrorMessage( |
473 keys::kNoExtensionError, extension_id_); | 475 keys::kNoExtensionError, extension_id_); |
474 return false; | 476 return false; |
475 } | 477 } |
476 | 478 |
477 const ManagementPolicy* policy = | 479 const ManagementPolicy* policy = |
478 ExtensionSystem::Get(GetProfile())->management_policy(); | 480 ExtensionSystem::Get(GetProfile())->management_policy(); |
479 if (!policy->UserMayModifySettings(extension, NULL) || | 481 if (!policy->UserMayModifySettings(extension, NULL) || |
480 (!params->enabled && policy->MustRemainEnabled(extension, NULL)) || | 482 (!params->enabled && policy->MustRemainEnabled(extension, NULL)) || |
(...skipping 344 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
825 return g_factory.Pointer(); | 827 return g_factory.Pointer(); |
826 } | 828 } |
827 | 829 |
828 void ManagementAPI::OnListenerAdded(const EventListenerInfo& details) { | 830 void ManagementAPI::OnListenerAdded(const EventListenerInfo& details) { |
829 management_event_router_.reset( | 831 management_event_router_.reset( |
830 new ManagementEventRouter(Profile::FromBrowserContext(browser_context_))); | 832 new ManagementEventRouter(Profile::FromBrowserContext(browser_context_))); |
831 EventRouter::Get(browser_context_)->UnregisterObserver(this); | 833 EventRouter::Get(browser_context_)->UnregisterObserver(this); |
832 } | 834 } |
833 | 835 |
834 } // namespace extensions | 836 } // namespace extensions |
OLD | NEW |