Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(113)

Side by Side Diff: chrome/browser/extensions/extensions_service.cc

Issue 63056: TBR: Revert "Implement chromium.self in content scripts..." (Closed)
Patch Set: Created 11 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2006-2008 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/extensions_service.h" 5 #include "chrome/browser/extensions/extensions_service.h"
6 6
7 #include "base/file_util.h" 7 #include "base/file_util.h"
8 #include "base/scoped_handle.h" 8 #include "base/scoped_handle.h"
9 #include "base/scoped_temp_dir.h" 9 #include "base/scoped_temp_dir.h"
10 #include "base/string_util.h" 10 #include "base/string_util.h"
(...skipping 240 matching lines...) Expand 10 before | Expand all | Expand 10 after
251 // Explicit UI loads are always noisy. 251 // Explicit UI loads are always noisy.
252 alert_on_error_ = true; 252 alert_on_error_ = true;
253 253
254 FilePath extension_path = path_in; 254 FilePath extension_path = path_in;
255 if (!file_util::AbsolutePath(&extension_path)) 255 if (!file_util::AbsolutePath(&extension_path))
256 NOTREACHED(); 256 NOTREACHED();
257 257
258 LOG(INFO) << "Loading single extension from " << 258 LOG(INFO) << "Loading single extension from " <<
259 WideToASCII(extension_path.BaseName().ToWStringHack()); 259 WideToASCII(extension_path.BaseName().ToWStringHack());
260 260
261 Extension* extension = LoadExtension(extension_path, 261 Extension* extension = LoadExtension(extension_path);
262 false); // don't require ID
263 if (extension) { 262 if (extension) {
263 if (extension->id().empty()) {
264 // Generate an ID
265 static int counter = 0;
266 std::string id = StringPrintf("%x", counter);
267 ++counter;
268
269 // pad the string out to 40 chars with zeroes.
270 id.insert(0, 40 - id.length(), '0');
271 extension->set_id(id);
272 }
264 ExtensionList* extensions = new ExtensionList; 273 ExtensionList* extensions = new ExtensionList;
265 extensions->push_back(extension); 274 extensions->push_back(extension);
266 ReportExtensionsLoaded(extensions); 275 ReportExtensionsLoaded(extensions);
267 } 276 }
268 } 277 }
269 278
270 Extension* ExtensionsServiceBackend::LoadExtensionCurrentVersion( 279 Extension* ExtensionsServiceBackend::LoadExtensionCurrentVersion(
271 const FilePath& extension_path) { 280 const FilePath& extension_path) {
272 std::string version_str; 281 std::string version_str;
273 if (!ReadCurrentVersion(extension_path, &version_str)) { 282 if (!ReadCurrentVersion(extension_path, &version_str)) {
274 ReportExtensionLoadError(extension_path, 283 ReportExtensionLoadError(extension_path,
275 StringPrintf("Could not read '%s' file.", 284 StringPrintf("Could not read '%s' file.",
276 ExtensionsService::kCurrentVersionFileName)); 285 ExtensionsService::kCurrentVersionFileName));
277 return NULL; 286 return NULL;
278 } 287 }
279 288
280 LOG(INFO) << " " << 289 LOG(INFO) << " " <<
281 WideToASCII(extension_path.BaseName().ToWStringHack()) << 290 WideToASCII(extension_path.BaseName().ToWStringHack()) <<
282 " version: " << version_str; 291 " version: " << version_str;
283 292
284 return LoadExtension(extension_path.AppendASCII(version_str), 293 return LoadExtension(extension_path.AppendASCII(version_str));
285 true); // require id
286 } 294 }
287 295
288 Extension* ExtensionsServiceBackend::LoadExtension( 296 Extension* ExtensionsServiceBackend::LoadExtension(
289 const FilePath& extension_path, bool require_id) { 297 const FilePath& extension_path) {
290 FilePath manifest_path = 298 FilePath manifest_path =
291 extension_path.AppendASCII(Extension::kManifestFilename); 299 extension_path.AppendASCII(Extension::kManifestFilename);
292 if (!file_util::PathExists(manifest_path)) { 300 if (!file_util::PathExists(manifest_path)) {
293 ReportExtensionLoadError(extension_path, Extension::kInvalidManifestError); 301 ReportExtensionLoadError(extension_path, Extension::kInvalidManifestError);
294 return NULL; 302 return NULL;
295 } 303 }
296 304
297 JSONFileValueSerializer serializer(manifest_path); 305 JSONFileValueSerializer serializer(manifest_path);
298 std::string error; 306 std::string error;
299 scoped_ptr<Value> root(serializer.Deserialize(&error)); 307 scoped_ptr<Value> root(serializer.Deserialize(&error));
300 if (!root.get()) { 308 if (!root.get()) {
301 ReportExtensionLoadError(extension_path, error); 309 ReportExtensionLoadError(extension_path, error);
302 return NULL; 310 return NULL;
303 } 311 }
304 312
305 if (!root->IsType(Value::TYPE_DICTIONARY)) { 313 if (!root->IsType(Value::TYPE_DICTIONARY)) {
306 ReportExtensionLoadError(extension_path, Extension::kInvalidManifestError); 314 ReportExtensionLoadError(extension_path, Extension::kInvalidManifestError);
307 return NULL; 315 return NULL;
308 } 316 }
309 317
310 scoped_ptr<Extension> extension(new Extension(extension_path)); 318 scoped_ptr<Extension> extension(new Extension(extension_path));
311 if (!extension->InitFromValue(*static_cast<DictionaryValue*>(root.get()), 319 if (!extension->InitFromValue(*static_cast<DictionaryValue*>(root.get()),
312 require_id, &error)) { 320 &error)) {
313 ReportExtensionLoadError(extension_path, error); 321 ReportExtensionLoadError(extension_path, error);
314 return NULL; 322 return NULL;
315 } 323 }
316 324
317 // Validate that claimed resources actually exist. 325 // Validate that claimed resources actually exist.
318 for (size_t i = 0; i < extension->content_scripts().size(); ++i) { 326 for (size_t i = 0; i < extension->content_scripts().size(); ++i) {
319 const UserScript& script = extension->content_scripts()[i]; 327 const UserScript& script = extension->content_scripts()[i];
320 328
321 for (size_t j = 0; j < script.js_scripts().size(); j++) { 329 for (size_t j = 0; j < script.js_scripts().size(); j++) {
322 const FilePath& path = script.js_scripts()[j].path(); 330 const FilePath& path = script.js_scripts()[j].path();
(...skipping 300 matching lines...) Expand 10 before | Expand all | Expand 10 after
623 631
624 // Read and verify the extension. 632 // Read and verify the extension.
625 scoped_ptr<DictionaryValue> manifest(ReadManifest(source_file)); 633 scoped_ptr<DictionaryValue> manifest(ReadManifest(source_file));
626 if (!manifest.get()) { 634 if (!manifest.get()) {
627 // ReadManifest has already reported the extension error. 635 // ReadManifest has already reported the extension error.
628 return false; 636 return false;
629 } 637 }
630 DictionaryValue* dict = manifest.get(); 638 DictionaryValue* dict = manifest.get();
631 Extension extension; 639 Extension extension;
632 std::string error; 640 std::string error;
633 if (!extension.InitFromValue(*dict, 641 if (!extension.InitFromValue(*dict, &error)) {
634 true, // require ID
635 &error)) {
636 ReportExtensionInstallError(source_file, 642 ReportExtensionInstallError(source_file,
637 "Invalid extension manifest."); 643 "Invalid extension manifest.");
638 return false; 644 return false;
639 } 645 }
640 646
641 // ID is required for installed extensions. 647 // ID is required for installed extensions.
642 if (extension.id().empty()) { 648 if (extension.id().empty()) {
643 ReportExtensionInstallError(source_file, "Required value 'id' is missing."); 649 ReportExtensionInstallError(source_file, "Required value 'id' is missing.");
644 return false; 650 return false;
645 } 651 }
(...skipping 191 matching lines...) Expand 10 before | Expand all | Expand 10 after
837 843
838 bool ExtensionsServiceBackend::ShouldInstall(const std::string& id, 844 bool ExtensionsServiceBackend::ShouldInstall(const std::string& id,
839 const std::string& version) { 845 const std::string& version) {
840 FilePath dir(install_directory_.AppendASCII(id.c_str())); 846 FilePath dir(install_directory_.AppendASCII(id.c_str()));
841 std::string current_version; 847 std::string current_version;
842 if (ReadCurrentVersion(dir, &current_version)) { 848 if (ReadCurrentVersion(dir, &current_version)) {
843 return !CheckCurrentVersion(version, current_version, dir); 849 return !CheckCurrentVersion(version, current_version, dir);
844 } 850 }
845 return true; 851 return true;
846 } 852 }
OLDNEW
« no previous file with comments | « chrome/browser/extensions/extensions_service.h ('k') | chrome/browser/extensions/test_extension_loader.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698