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

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

Issue 2697463002: Convert utility process extension Unpacker IPC to mojo (Closed)
Patch Set: Use MakeUnique when creating the utility mojo client. Created 3 years, 10 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 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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/zipfile_installer.h" 5 #include "chrome/browser/extensions/zipfile_installer.h"
6 6
7 #include "base/files/file_util.h" 7 #include "base/files/file_util.h"
8 #include "base/path_service.h" 8 #include "base/path_service.h"
9 #include "base/threading/thread_task_runner_handle.h" 9 #include "base/threading/thread_task_runner_handle.h"
10 #include "chrome/browser/extensions/extension_error_reporter.h" 10 #include "chrome/browser/extensions/extension_error_reporter.h"
11 #include "chrome/browser/extensions/extension_service.h" 11 #include "chrome/browser/extensions/extension_service.h"
12 #include "chrome/browser/extensions/unpacked_installer.h" 12 #include "chrome/browser/extensions/unpacked_installer.h"
13 #include "chrome/browser/profiles/profile.h" 13 #include "chrome/browser/profiles/profile.h"
14 #include "chrome/grit/generated_resources.h" 14 #include "chrome/grit/generated_resources.h"
15 #include "content/public/browser/browser_thread.h" 15 #include "content/public/browser/browser_thread.h"
16 #include "content/public/browser/utility_process_host.h"
17 #include "extensions/common/extension_utility_messages.h"
18 #include "ui/base/l10n/l10n_util.h" 16 #include "ui/base/l10n/l10n_util.h"
19 17
20 using content::BrowserThread;
21 using content::UtilityProcessHost;
22
23 namespace { 18 namespace {
24 19
25 const char kExtensionHandlerTempDirError[] = 20 const char kExtensionHandlerTempDirError[] =
26 "Could not create temporary directory for zipped extension."; 21 "Could not create temporary directory for zipped extension.";
22 const char kExtensionHandlerFileUnzipError[] =
23 "Could not unzip extension for install.";
27 24
28 } // namespace 25 } // namespace
29 26
30 namespace extensions { 27 namespace extensions {
31 28
32 ZipFileInstaller::ZipFileInstaller(ExtensionService* extension_service) 29 // static
33 : be_noisy_on_failure_(true), 30 scoped_refptr<ZipFileInstaller> ZipFileInstaller::Create(
34 extension_service_weak_(extension_service->AsWeakPtr()) { 31 ExtensionService* service) {
32 DCHECK(service);
33 return make_scoped_refptr(new ZipFileInstaller(service));
35 } 34 }
36 35
37 void ZipFileInstaller::LoadFromZipFile(const base::FilePath& path) { 36 void ZipFileInstaller::LoadFromZipFile(const base::FilePath& zip_file) {
38 DCHECK_CURRENTLY_ON(BrowserThread::UI); 37 DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
39 zip_path_ = path; 38
40 BrowserThread::PostTask(BrowserThread::FILE, 39 zip_file_ = zip_file;
41 FROM_HERE, 40
42 base::Bind(&ZipFileInstaller::PrepareTempDir, this)); 41 content::BrowserThread::PostTask(
42 content::BrowserThread::FILE, FROM_HERE,
43 base::Bind(&ZipFileInstaller::PrepareTempDir, this, zip_file_));
43 } 44 }
44 45
45 void ZipFileInstaller::PrepareTempDir() { 46 ZipFileInstaller::ZipFileInstaller(ExtensionService* service)
46 CHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE)); 47 : be_noisy_on_failure_(true),
48 extension_service_weak_(service->AsWeakPtr()) {}
49
50 ZipFileInstaller::~ZipFileInstaller() = default;
51
52 void ZipFileInstaller::PrepareTempDir(const base::FilePath& zip_file) {
53 DCHECK_CURRENTLY_ON(content::BrowserThread::FILE);
54
55 base::FilePath dir_temp;
56 PathService::Get(base::DIR_TEMP, &dir_temp);
57
58 base::FilePath::StringType dir_name =
59 zip_file.RemoveExtension().BaseName().value() + FILE_PATH_LITERAL("_");
60
47 base::FilePath temp_dir; 61 base::FilePath temp_dir;
Devlin 2017/02/14 17:24:59 dir_temp vs temp_dir is a pretty ambiguous distinc
Noel Gordon 2017/02/15 17:28:08 Code on diff-left was that too :) and a tried to m
48 PathService::Get(base::DIR_TEMP, &temp_dir); 62 if (!base::CreateTemporaryDirInDir(dir_temp, dir_name, &temp_dir)) {
49 base::FilePath new_temp_dir; 63 content::BrowserThread::PostTask(
50 if (!base::CreateTemporaryDirInDir( 64 content::BrowserThread::UI, FROM_HERE,
51 temp_dir, 65 base::Bind(&ZipFileInstaller::ReportErrorOnUIThread, this,
52 zip_path_.RemoveExtension().BaseName().value() + 66 std::string(kExtensionHandlerTempDirError)));
53 FILE_PATH_LITERAL("_"),
54 &new_temp_dir)) {
55 OnUnzipFailed(std::string(kExtensionHandlerTempDirError));
56 return; 67 return;
57 } 68 }
58 BrowserThread::PostTask( 69
59 BrowserThread::IO, 70 content::BrowserThread::PostTask(
60 FROM_HERE, 71 content::BrowserThread::UI, FROM_HERE,
61 base::Bind(&ZipFileInstaller::StartWorkOnIOThread, this, new_temp_dir)); 72 base::Bind(&ZipFileInstaller::UnzipOnUIThread, this, temp_dir));
62 } 73 }
63 74
64 ZipFileInstaller::~ZipFileInstaller() { 75 void ZipFileInstaller::UnzipOnUIThread(const base::FilePath& temp_dir) {
76 DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
77 DCHECK(!utility_process_mojo_client_);
78 DCHECK(!temp_dir.empty());
79
80 temp_dir_ = temp_dir;
81
82 utility_process_mojo_client_ = base::MakeUnique<
83 content::UtilityProcessMojoClient<extensions::mojom::ExtensionUnpacker>>(
84 l10n_util::GetStringUTF16(IDS_UTILITY_PROCESS_ZIP_FILE_INSTALLER_NAME));
85 utility_process_mojo_client_->set_error_callback(
86 base::Bind(&ZipFileInstaller::UnzipDone, this, false));
87
88 utility_process_mojo_client_->set_exposed_directory(temp_dir_);
89
90 utility_process_mojo_client_->Start();
91
92 utility_process_mojo_client_->service()->Unzip(
93 zip_file_, temp_dir_, base::Bind(&ZipFileInstaller::UnzipDone, this));
65 } 94 }
66 95
67 // static 96 void ZipFileInstaller::UnzipDone(bool success) {
68 scoped_refptr<ZipFileInstaller> ZipFileInstaller::Create( 97 DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
69 ExtensionService* extension_service) {
70 DCHECK(extension_service);
71 return scoped_refptr<ZipFileInstaller>(
72 new ZipFileInstaller(extension_service));
73 }
74 98
75 void ZipFileInstaller::StartWorkOnIOThread(const base::FilePath& temp_dir) { 99 utility_process_mojo_client_.reset();
76 CHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
77 UtilityProcessHost* host =
78 UtilityProcessHost::Create(this,
79 base::ThreadTaskRunnerHandle::Get().get());
80 host->SetName(l10n_util::GetStringUTF16(
81 IDS_UTILITY_PROCESS_ZIP_FILE_INSTALLER_NAME));
82 host->SetExposedDir(temp_dir);
83 host->Send(new ExtensionUtilityMsg_UnzipToDir(zip_path_, temp_dir));
84 }
85 100
86 void ZipFileInstaller::ReportSuccessOnUIThread( 101 if (!success) {
87 const base::FilePath& unzipped_path) { 102 ReportErrorOnUIThread(std::string(kExtensionHandlerFileUnzipError));
Devlin 2017/02/14 17:24:59 Since all this happens on the UI thread, we can ju
Noel Gordon 2017/02/15 17:28:08 I'll take part of the early return idea, but pleas
88 CHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 103 } else if (extension_service_weak_) {
89 if (extension_service_weak_.get()) 104 UnpackedInstaller::Create(extension_service_weak_.get())->Load(temp_dir_);
90 UnpackedInstaller::Create(extension_service_weak_.get()) 105 }
91 ->Load(unzipped_path);
92 } 106 }
93 107
94 void ZipFileInstaller::ReportErrorOnUIThread(const std::string& error) { 108 void ZipFileInstaller::ReportErrorOnUIThread(const std::string& error) {
95 CHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 109 DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
96 if (extension_service_weak_.get()) { 110
111 if (extension_service_weak_) {
97 ExtensionErrorReporter::GetInstance()->ReportLoadError( 112 ExtensionErrorReporter::GetInstance()->ReportLoadError(
98 zip_path_, 113 zip_file_, error, extension_service_weak_->profile(),
99 error,
100 extension_service_weak_->profile(),
101 be_noisy_on_failure_); 114 be_noisy_on_failure_);
102 } 115 }
103 } 116 }
104 117
105 void ZipFileInstaller::OnUnzipSucceeded(const base::FilePath& unzipped_path) {
106 DCHECK_CURRENTLY_ON(BrowserThread::IO);
107 BrowserThread::PostTask(
108 BrowserThread::UI,
109 FROM_HERE,
110 base::Bind(
111 &ZipFileInstaller::ReportSuccessOnUIThread, this, unzipped_path));
112 }
113
114 void ZipFileInstaller::OnUnzipFailed(const std::string& error) {
115 DCHECK_CURRENTLY_ON(BrowserThread::IO);
116 BrowserThread::PostTask(
117 BrowserThread::UI,
118 FROM_HERE,
119 base::Bind(&ZipFileInstaller::ReportErrorOnUIThread, this, error));
120 }
121
122 bool ZipFileInstaller::OnMessageReceived(const IPC::Message& message) {
123 bool handled = true;
124 IPC_BEGIN_MESSAGE_MAP(ZipFileInstaller, message)
125 IPC_MESSAGE_HANDLER(ExtensionUtilityHostMsg_UnzipToDir_Succeeded,
126 OnUnzipSucceeded)
127 IPC_MESSAGE_HANDLER(ExtensionUtilityHostMsg_UnzipToDir_Failed, OnUnzipFailed)
128 IPC_MESSAGE_UNHANDLED(handled = false)
129 IPC_END_MESSAGE_MAP()
130 return handled;
131 }
132
133 } // namespace extensions 118 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698