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
3 // found in the LICENSE file.
5 #include "chrome/common/importer/firefox_importer_utils.h"
9 #include "base/files/file_util.h"
10 #include "base/path_service.h"
11 #include "base/strings/string16.h"
12 #include "base/win/registry.h"
14 // NOTE: Keep these in order since we need test all those paths according
15 // to priority. For example. One machine has multiple users. One non-admin
16 // user installs Firefox 2, which causes there is a Firefox2 entry under HKCU.
17 // One admin user installs Firefox 3, which causes there is a Firefox 3 entry
18 // under HKLM. So when the non-admin user log in, we should deal with Firefox 2
19 // related data instead of Firefox 3.
20 static const HKEY kFireFoxRegistryPaths
[] = {
25 static const wchar_t* kFirefoxPath
= L
"Software\\Mozilla\\Mozilla Firefox";
26 static const wchar_t* kCurrentVersion
= L
"CurrentVersion";
28 int GetCurrentFirefoxMajorVersionFromRegistry() {
29 TCHAR ver_buffer
[128];
30 DWORD ver_buffer_length
= sizeof(ver_buffer
);
31 int highest_version
= 0;
32 // When installing Firefox with admin account, the product keys will be
33 // written under HKLM\Mozilla. Otherwise it the keys will be written under
35 for (int i
= 0; i
< arraysize(kFireFoxRegistryPaths
); ++i
) {
36 base::win::RegKey
reg_key(kFireFoxRegistryPaths
[i
], kFirefoxPath
,
39 LONG result
= reg_key
.ReadValue(kCurrentVersion
, ver_buffer
,
40 &ver_buffer_length
, NULL
);
41 if (result
!= ERROR_SUCCESS
)
43 highest_version
= std::max(highest_version
, _wtoi(ver_buffer
));
45 return highest_version
;
48 base::FilePath
GetFirefoxInstallPathFromRegistry() {
49 // Detects the path that Firefox is installed in.
50 base::string16 registry_path
= kFirefoxPath
;
51 wchar_t buffer
[MAX_PATH
];
52 DWORD buffer_length
= sizeof(buffer
);
53 base::win::RegKey
reg_key(HKEY_LOCAL_MACHINE
, registry_path
.c_str(),
55 LONG result
= reg_key
.ReadValue(kCurrentVersion
, buffer
,
56 &buffer_length
, NULL
);
57 if (result
!= ERROR_SUCCESS
)
58 return base::FilePath();
60 registry_path
+= L
"\\" + base::string16(buffer
) + L
"\\Main";
61 buffer_length
= sizeof(buffer
);
62 base::win::RegKey
reg_key_directory(HKEY_LOCAL_MACHINE
,
63 registry_path
.c_str(), KEY_READ
);
64 result
= reg_key_directory
.ReadValue(L
"Install Directory", buffer
,
65 &buffer_length
, NULL
);
67 return (result
!= ERROR_SUCCESS
) ? base::FilePath() : base::FilePath(buffer
);
70 base::FilePath
GetProfilesINI() {
71 base::FilePath ini_file
;
72 // The default location of the profile folder containing user data is
73 // under the "Application Data" folder in Windows XP, Vista, and 7.
74 if (!PathService::Get(base::DIR_APP_DATA
, &ini_file
))
75 return base::FilePath();
77 ini_file
= ini_file
.AppendASCII("Mozilla");
78 ini_file
= ini_file
.AppendASCII("Firefox");
79 ini_file
= ini_file
.AppendASCII("profiles.ini");
81 return base::PathExists(ini_file
) ? ini_file
: base::FilePath();