| OLD | NEW | 
|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "mojo/shell/application_instance.h" | 5 #include "mojo/shell/application_instance.h" | 
| 6 | 6 | 
|  | 7 #include <utility> | 
|  | 8 | 
| 7 #include "base/bind.h" | 9 #include "base/bind.h" | 
| 8 #include "base/stl_util.h" | 10 #include "base/stl_util.h" | 
| 9 #include "mojo/application/public/interfaces/content_handler.mojom.h" | 11 #include "mojo/application/public/interfaces/content_handler.mojom.h" | 
| 10 #include "mojo/common/common_type_converters.h" | 12 #include "mojo/common/common_type_converters.h" | 
| 11 #include "mojo/common/url_type_converters.h" | 13 #include "mojo/common/url_type_converters.h" | 
| 12 #include "mojo/shell/application_manager.h" | 14 #include "mojo/shell/application_manager.h" | 
| 13 | 15 | 
| 14 namespace mojo { | 16 namespace mojo { | 
| 15 namespace shell { | 17 namespace shell { | 
| 16 | 18 | 
| 17 ApplicationInstance::ApplicationInstance( | 19 ApplicationInstance::ApplicationInstance( | 
| 18     ApplicationPtr application, | 20     ApplicationPtr application, | 
| 19     ApplicationManager* manager, | 21     ApplicationManager* manager, | 
| 20     const Identity& identity, | 22     const Identity& identity, | 
| 21     uint32_t requesting_content_handler_id, | 23     uint32_t requesting_content_handler_id, | 
| 22     const base::Closure& on_application_end) | 24     const base::Closure& on_application_end) | 
| 23     : manager_(manager), | 25     : manager_(manager), | 
| 24       identity_(identity), | 26       identity_(identity), | 
| 25       allow_any_application_(identity.filter().size() == 1 && | 27       allow_any_application_(identity.filter().size() == 1 && | 
| 26                              identity.filter().count("*") == 1), | 28                              identity.filter().count("*") == 1), | 
| 27       requesting_content_handler_id_(requesting_content_handler_id), | 29       requesting_content_handler_id_(requesting_content_handler_id), | 
| 28       on_application_end_(on_application_end), | 30       on_application_end_(on_application_end), | 
| 29       application_(application.Pass()), | 31       application_(std::move(application)), | 
| 30       binding_(this), | 32       binding_(this), | 
| 31       queue_requests_(false), | 33       queue_requests_(false), | 
| 32       native_runner_(nullptr), | 34       native_runner_(nullptr), | 
| 33       pid_(base::kNullProcessId) { | 35       pid_(base::kNullProcessId) {} | 
| 34 } |  | 
| 35 | 36 | 
| 36 ApplicationInstance::~ApplicationInstance() { | 37 ApplicationInstance::~ApplicationInstance() { | 
| 37   for (auto request : queued_client_requests_) | 38   for (auto request : queued_client_requests_) | 
| 38     request->connect_callback().Run(kInvalidContentHandlerID); | 39     request->connect_callback().Run(kInvalidContentHandlerID); | 
| 39   STLDeleteElements(&queued_client_requests_); | 40   STLDeleteElements(&queued_client_requests_); | 
| 40 } | 41 } | 
| 41 | 42 | 
| 42 void ApplicationInstance::InitializeApplication() { | 43 void ApplicationInstance::InitializeApplication() { | 
| 43   ShellPtr shell; | 44   ShellPtr shell; | 
| 44   binding_.Bind(GetProxy(&shell)); | 45   binding_.Bind(GetProxy(&shell)); | 
| 45   binding_.set_connection_error_handler([this]() { OnConnectionError(); }); | 46   binding_.set_connection_error_handler([this]() { OnConnectionError(); }); | 
| 46   application_->Initialize(shell.Pass(), identity_.url().spec()); | 47   application_->Initialize(std::move(shell), identity_.url().spec()); | 
| 47 } | 48 } | 
| 48 | 49 | 
| 49 void ApplicationInstance::ConnectToClient( | 50 void ApplicationInstance::ConnectToClient( | 
| 50     scoped_ptr<ConnectToApplicationParams> params) { | 51     scoped_ptr<ConnectToApplicationParams> params) { | 
| 51   if (queue_requests_) { | 52   if (queue_requests_) { | 
| 52     queued_client_requests_.push_back(params.release()); | 53     queued_client_requests_.push_back(params.release()); | 
| 53     return; | 54     return; | 
| 54   } | 55   } | 
| 55 | 56 | 
| 56   CallAcceptConnection(params.Pass()); | 57   CallAcceptConnection(std::move(params)); | 
| 57 } | 58 } | 
| 58 | 59 | 
| 59 void ApplicationInstance::SetNativeRunner(NativeRunner* native_runner) { | 60 void ApplicationInstance::SetNativeRunner(NativeRunner* native_runner) { | 
| 60   native_runner_ = native_runner; | 61   native_runner_ = native_runner; | 
| 61   pid_ = native_runner_->GetApplicationPID(); | 62   pid_ = native_runner_->GetApplicationPID(); | 
| 62 } | 63 } | 
| 63 | 64 | 
| 64 base::ProcessId ApplicationInstance::GetProcessId() const { | 65 base::ProcessId ApplicationInstance::GetProcessId() const { | 
| 65   return pid_; | 66   return pid_; | 
| 66 } | 67 } | 
| (...skipping 16 matching lines...) Expand all  Loading... | 
| 83       identity_.filter().find(url.spec()) != identity_.filter().end()) { | 84       identity_.filter().find(url.spec()) != identity_.filter().end()) { | 
| 84     CapabilityFilter capability_filter = GetPermissiveCapabilityFilter(); | 85     CapabilityFilter capability_filter = GetPermissiveCapabilityFilter(); | 
| 85     if (!filter.is_null()) | 86     if (!filter.is_null()) | 
| 86       capability_filter = filter->filter.To<CapabilityFilter>(); | 87       capability_filter = filter->filter.To<CapabilityFilter>(); | 
| 87 | 88 | 
| 88     scoped_ptr<ConnectToApplicationParams> params( | 89     scoped_ptr<ConnectToApplicationParams> params( | 
| 89         new ConnectToApplicationParams); | 90         new ConnectToApplicationParams); | 
| 90     params->SetSource(this); | 91     params->SetSource(this); | 
| 91     GURL app_url(app_request->url); | 92     GURL app_url(app_request->url); | 
| 92     params->SetTargetURLRequest( | 93     params->SetTargetURLRequest( | 
| 93         app_request.Pass(), | 94         std::move(app_request), | 
| 94         Identity(app_url, std::string(), capability_filter)); | 95         Identity(app_url, std::string(), capability_filter)); | 
| 95     params->set_services(services.Pass()); | 96     params->set_services(std::move(services)); | 
| 96     params->set_exposed_services(exposed_services.Pass()); | 97     params->set_exposed_services(std::move(exposed_services)); | 
| 97     params->set_connect_callback(callback); | 98     params->set_connect_callback(callback); | 
| 98     manager_->ConnectToApplication(params.Pass()); | 99     manager_->ConnectToApplication(std::move(params)); | 
| 99   } else { | 100   } else { | 
| 100     LOG(WARNING) << "CapabilityFilter prevented connection from: " << | 101     LOG(WARNING) << "CapabilityFilter prevented connection from: " << | 
| 101         identity_.url() << " to: " << url.spec(); | 102         identity_.url() << " to: " << url.spec(); | 
| 102     callback.Run(kInvalidContentHandlerID); | 103     callback.Run(kInvalidContentHandlerID); | 
| 103   } | 104   } | 
| 104 } | 105 } | 
| 105 | 106 | 
| 106 void ApplicationInstance::QuitApplication() { | 107 void ApplicationInstance::QuitApplication() { | 
| 107   queue_requests_ = true; | 108   queue_requests_ = true; | 
| 108   application_->OnQuitRequested( | 109   application_->OnQuitRequested( | 
| 109       base::Bind(&ApplicationInstance::OnQuitRequestedResult, | 110       base::Bind(&ApplicationInstance::OnQuitRequestedResult, | 
| 110                  base::Unretained(this))); | 111                  base::Unretained(this))); | 
| 111 } | 112 } | 
| 112 | 113 | 
| 113 void ApplicationInstance::CallAcceptConnection( | 114 void ApplicationInstance::CallAcceptConnection( | 
| 114     scoped_ptr<ConnectToApplicationParams> params) { | 115     scoped_ptr<ConnectToApplicationParams> params) { | 
| 115   params->connect_callback().Run(requesting_content_handler_id_); | 116   params->connect_callback().Run(requesting_content_handler_id_); | 
| 116   AllowedInterfaces interfaces; | 117   AllowedInterfaces interfaces; | 
| 117   interfaces.insert("*"); | 118   interfaces.insert("*"); | 
| 118   if (!params->source().is_null()) | 119   if (!params->source().is_null()) | 
| 119     interfaces = GetAllowedInterfaces(params->source().filter(), identity_); | 120     interfaces = GetAllowedInterfaces(params->source().filter(), identity_); | 
| 120 | 121 | 
| 121   application_->AcceptConnection( | 122   application_->AcceptConnection( | 
| 122       params->source().url().spec(), params->TakeServices(), | 123       params->source().url().spec(), params->TakeServices(), | 
| 123       params->TakeExposedServices(), Array<String>::From(interfaces).Pass(), | 124       params->TakeExposedServices(), Array<String>::From(interfaces), | 
| 124       params->target().url().spec()); | 125       params->target().url().spec()); | 
| 125 } | 126 } | 
| 126 | 127 | 
| 127 void ApplicationInstance::OnConnectionError() { | 128 void ApplicationInstance::OnConnectionError() { | 
| 128   std::vector<ConnectToApplicationParams*> queued_client_requests; | 129   std::vector<ConnectToApplicationParams*> queued_client_requests; | 
| 129   queued_client_requests_.swap(queued_client_requests); | 130   queued_client_requests_.swap(queued_client_requests); | 
| 130   auto manager = manager_; | 131   auto manager = manager_; | 
| 131   manager_->OnApplicationInstanceError(this); | 132   manager_->OnApplicationInstanceError(this); | 
| 132   //|this| is deleted. | 133   //|this| is deleted. | 
| 133 | 134 | 
| (...skipping 14 matching lines...) Expand all  Loading... | 
| 148     // 6) connect_request_2 is queued (and eventually gets here), but its | 149     // 6) connect_request_2 is queued (and eventually gets here), but its | 
| 149     //    original_request field was already lost to NetworkFetcher at step (2). | 150     //    original_request field was already lost to NetworkFetcher at step (2). | 
| 150     // | 151     // | 
| 151     // TODO(yzshen): It seems we should register a pending application instance | 152     // TODO(yzshen): It seems we should register a pending application instance | 
| 152     // before starting the fetch. So at step (2) the application manager knows | 153     // before starting the fetch. So at step (2) the application manager knows | 
| 153     // that it can wait for the first fetch to complete instead of doing a | 154     // that it can wait for the first fetch to complete instead of doing a | 
| 154     // second one directly. | 155     // second one directly. | 
| 155     if (!request->target_url_request()) { | 156     if (!request->target_url_request()) { | 
| 156       URLRequestPtr url_request = mojo::URLRequest::New(); | 157       URLRequestPtr url_request = mojo::URLRequest::New(); | 
| 157       url_request->url = request->target().url().spec(); | 158       url_request->url = request->target().url().spec(); | 
| 158       request->SetTargetURLRequest(url_request.Pass(), request->target()); | 159       request->SetTargetURLRequest(std::move(url_request), request->target()); | 
| 159     } | 160     } | 
| 160     manager->ConnectToApplication(make_scoped_ptr(request)); | 161     manager->ConnectToApplication(make_scoped_ptr(request)); | 
| 161   } | 162   } | 
| 162 } | 163 } | 
| 163 | 164 | 
| 164 void ApplicationInstance::OnQuitRequestedResult(bool can_quit) { | 165 void ApplicationInstance::OnQuitRequestedResult(bool can_quit) { | 
| 165   if (can_quit) | 166   if (can_quit) | 
| 166     return; | 167     return; | 
| 167 | 168 | 
| 168   queue_requests_ = false; | 169   queue_requests_ = false; | 
| 169   for (auto request : queued_client_requests_) | 170   for (auto request : queued_client_requests_) | 
| 170     CallAcceptConnection(make_scoped_ptr(request)); | 171     CallAcceptConnection(make_scoped_ptr(request)); | 
| 171 | 172 | 
| 172   queued_client_requests_.clear(); | 173   queued_client_requests_.clear(); | 
| 173 } | 174 } | 
| 174 | 175 | 
| 175 }  // namespace shell | 176 }  // namespace shell | 
| 176 }  // namespace mojo | 177 }  // namespace mojo | 
| OLD | NEW | 
|---|