OLD | NEW |
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/browser/chromeos/login/scoped_gaia_auth_extension.h" | 5 #include "chrome/browser/chromeos/login/scoped_gaia_auth_extension.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "chrome/browser/chromeos/system/statistics_provider.h" | 8 #include "chrome/browser/chromeos/system/statistics_provider.h" |
9 #include "chrome/browser/extensions/component_loader.h" | 9 #include "chrome/browser/extensions/component_loader.h" |
10 #include "chrome/browser/extensions/extension_service.h" | 10 #include "chrome/browser/extensions/extension_service.h" |
11 #include "chrome/browser/extensions/extension_system.h" | 11 #include "chrome/browser/extensions/extension_system.h" |
12 #include "chrome/browser/profiles/profile.h" | 12 #include "chrome/browser/profiles/profile.h" |
13 #include "chrome/common/chrome_constants.h" | 13 #include "chrome/common/chrome_constants.h" |
14 #include "chrome/common/chrome_switches.h" | 14 #include "chrome/common/chrome_switches.h" |
| 15 #include "chromeos/chromeos_constants.h" |
15 #include "grit/browser_resources.h" | 16 #include "grit/browser_resources.h" |
16 | 17 |
17 namespace chromeos { | 18 namespace chromeos { |
18 | 19 |
19 namespace { | 20 namespace { |
20 | 21 |
21 extensions::ComponentLoader* GetComponentLoader(Profile* profile) { | 22 extensions::ComponentLoader* GetComponentLoader(Profile* profile) { |
22 extensions::ExtensionSystem* extension_system = | 23 extensions::ExtensionSystem* extension_system = |
23 extensions::ExtensionSystem::Get(profile); | 24 extensions::ExtensionSystem::Get(profile); |
24 ExtensionService* extension_service = extension_system->extension_service(); | 25 ExtensionService* extension_service = extension_system->extension_service(); |
25 return extension_service->component_loader(); | 26 return extension_service->component_loader(); |
26 } | 27 } |
27 | 28 |
28 void LoadGaiaAuthExtension(Profile* profile) { | 29 void LoadGaiaAuthExtension(Profile* profile) { |
29 extensions::ComponentLoader* component_loader = GetComponentLoader(profile); | 30 extensions::ComponentLoader* component_loader = GetComponentLoader(profile); |
30 const CommandLine* command_line = CommandLine::ForCurrentProcess(); | 31 const CommandLine* command_line = CommandLine::ForCurrentProcess(); |
31 if (command_line->HasSwitch(switches::kAuthExtensionPath)) { | 32 if (command_line->HasSwitch(switches::kAuthExtensionPath)) { |
32 base::FilePath auth_extension_path = | 33 base::FilePath auth_extension_path = |
33 command_line->GetSwitchValuePath(switches::kAuthExtensionPath); | 34 command_line->GetSwitchValuePath(switches::kAuthExtensionPath); |
34 component_loader->Add(IDR_GAIA_TEST_AUTH_MANIFEST, auth_extension_path); | 35 component_loader->Add(IDR_GAIA_TEST_AUTH_MANIFEST, auth_extension_path); |
35 return; | 36 return; |
36 } | 37 } |
37 | 38 |
38 bool force_keyboard_oobe = false; | 39 bool force_keyboard_oobe = false; |
39 chromeos::system::StatisticsProvider* provider = | 40 chromeos::system::StatisticsProvider* provider = |
40 chromeos::system::StatisticsProvider::GetInstance(); | 41 chromeos::system::StatisticsProvider::GetInstance(); |
41 provider->GetMachineFlag(chrome::kOemKeyboardDrivenOobeKey, | 42 provider->GetMachineFlag(chromeos::kOemKeyboardDrivenOobeKey, |
42 &force_keyboard_oobe); | 43 &force_keyboard_oobe); |
43 if (force_keyboard_oobe) { | 44 if (force_keyboard_oobe) { |
44 component_loader->Add(IDR_GAIA_AUTH_KEYBOARD_MANIFEST, | 45 component_loader->Add(IDR_GAIA_AUTH_KEYBOARD_MANIFEST, |
45 base::FilePath(FILE_PATH_LITERAL("gaia_auth"))); | 46 base::FilePath(FILE_PATH_LITERAL("gaia_auth"))); |
46 } else { | 47 } else { |
47 component_loader->Add(IDR_GAIA_AUTH_MANIFEST, | 48 component_loader->Add(IDR_GAIA_AUTH_MANIFEST, |
48 base::FilePath(FILE_PATH_LITERAL("gaia_auth"))); | 49 base::FilePath(FILE_PATH_LITERAL("gaia_auth"))); |
49 } | 50 } |
50 } | 51 } |
51 | 52 |
52 void UnloadGaiaAuthExtension(Profile* profile) { | 53 void UnloadGaiaAuthExtension(Profile* profile) { |
53 const char kGaiaAuthId[] = "mfffpogegjflfpflabcdkioaeobkgjik"; | 54 const char kGaiaAuthId[] = "mfffpogegjflfpflabcdkioaeobkgjik"; |
54 GetComponentLoader(profile)->Remove(kGaiaAuthId); | 55 GetComponentLoader(profile)->Remove(kGaiaAuthId); |
55 } | 56 } |
56 | 57 |
57 } // namespace | 58 } // namespace |
58 | 59 |
59 ScopedGaiaAuthExtension::ScopedGaiaAuthExtension(Profile* profile) | 60 ScopedGaiaAuthExtension::ScopedGaiaAuthExtension(Profile* profile) |
60 : profile_(profile) { | 61 : profile_(profile) { |
61 LoadGaiaAuthExtension(profile_); | 62 LoadGaiaAuthExtension(profile_); |
62 } | 63 } |
63 | 64 |
64 ScopedGaiaAuthExtension::~ScopedGaiaAuthExtension() { | 65 ScopedGaiaAuthExtension::~ScopedGaiaAuthExtension() { |
65 UnloadGaiaAuthExtension(profile_); | 66 UnloadGaiaAuthExtension(profile_); |
66 } | 67 } |
67 | 68 |
68 } // namespace chromeos | 69 } // namespace chromeos |
OLD | NEW |