// Copyright 2014 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef MOJO_SHELL_APPLICATION_MANAGER_H_ #define MOJO_SHELL_APPLICATION_MANAGER_H_ #include #include #include #include "base/macros.h" #include "base/memory/scoped_ptr.h" #include "base/memory/weak_ptr.h" #include "mojo/common/weak_interface_ptr_set.h" #include "mojo/public/cpp/bindings/interface_ptr_info.h" #include "mojo/public/cpp/bindings/interface_request.h" #include "mojo/shell/application_loader.h" #include "mojo/shell/capability_filter.h" #include "mojo/shell/connect_to_application_params.h" #include "mojo/shell/fetcher.h" #include "mojo/shell/identity.h" #include "mojo/shell/native_runner.h" #include "mojo/shell/public/interfaces/application_manager.mojom.h" #include "mojo/shell/public/interfaces/interface_provider.mojom.h" #include "mojo/shell/public/interfaces/shell.mojom.h" #include "mojo/shell/public/interfaces/shell_client.mojom.h" #include "url/gurl.h" namespace base { class FilePath; class SequencedWorkerPool; } namespace mojo { namespace shell { class PackageManager; class ApplicationInstance; class ContentHandlerConnection; class ApplicationManager { public: // API for testing. class TestAPI { public: explicit TestAPI(ApplicationManager* manager); ~TestAPI(); // Returns true if the shared instance has been created. static bool HasCreatedInstance(); // Returns true if there is a ApplicationInstance for this URL. bool HasRunningInstanceForURL(const GURL& url) const; private: ApplicationManager* manager_; DISALLOW_COPY_AND_ASSIGN(TestAPI); }; // Creates an ApplicationManager. // |package_manager| is an instance of an object that handles URL resolution, // fetching and updating of applications. See package_manager.h. explicit ApplicationManager(scoped_ptr package_manager); // |native_runner_factory| is an instance of an object capable of vending // implementations of NativeRunner, e.g. for in or out-of-process execution. // See native_runner.h and RunNativeApplication(). // |task_runner| provides access to a thread to perform file copy operations // on. This may be null only in testing environments where applications are // loaded via ApplicationLoader implementations. ApplicationManager(scoped_ptr package_manager, scoped_ptr native_runner_factory, base::TaskRunner* task_runner); ~ApplicationManager(); // Loads a service if necessary and establishes a new client connection. // Please see the comments in connect_to_application_params.h for more details // about the parameters. void ConnectToApplication(scoped_ptr params); // Sets the default Loader to be used if not overridden by SetLoaderForURL(). void set_default_loader(scoped_ptr loader) { default_loader_ = std::move(loader); } // Sets a Loader to be used for a specific url. void SetLoaderForURL(scoped_ptr loader, const GURL& url); // Destroys all Shell-ends of connections established with Applications. // Applications connected by this ApplicationManager will observe pipe errors // and have a chance to shutdown. void TerminateShellConnections(); // Removes a ApplicationInstance when it encounters an error. void OnApplicationInstanceError(ApplicationInstance* instance); ApplicationInstance* GetApplicationInstance(const Identity& identity) const; void CreateInstanceForHandle( ScopedHandle channel, const GURL& url, mojom::CapabilityFilterPtr filter, InterfaceRequest pid_receiver); void AddListener(mojom::ApplicationManagerListenerPtr listener); void GetRunningApplications( const Callback)>& callback); void ApplicationPIDAvailable(uint32_t id, base::ProcessId pid); private: using IdentityToInstanceMap = std::map; using URLToLoaderMap = std::map; // Takes the contents of |params| only when it returns true. bool ConnectToRunningApplication( scoped_ptr* params); InterfaceRequest CreateAndConnectToInstance( scoped_ptr params, ApplicationInstance** instance); InterfaceRequest CreateInstance( const Identity& target_id, const base::Closure& on_application_end, ApplicationInstance** resulting_instance); // Called once |fetcher| has found app. |params->app_url()| is the url of // the requested application before any mappings/resolution have been applied. // The corresponding URLRequest struct in |params| has been taken. void HandleFetchCallback(scoped_ptr params, scoped_ptr fetcher); void RunNativeApplication(InterfaceRequest request, bool start_sandboxed, scoped_ptr fetcher, ApplicationInstance* instance, const base::FilePath& file_path, bool path_exists); // Returns the appropriate loader for |url|, or the default loader if there is // no loader configured for the URL. ApplicationLoader* GetLoaderForURL(const GURL& url); void CleanupRunner(NativeRunner* runner); mojom::ApplicationInfoPtr CreateApplicationInfoForInstance( ApplicationInstance* instance) const; scoped_ptr const package_manager_; // Loader management. // Loaders are chosen in the order they are listed here. URLToLoaderMap url_to_loader_; scoped_ptr default_loader_; IdentityToInstanceMap identity_to_instance_; WeakInterfacePtrSet listeners_; base::TaskRunner* task_runner_; scoped_ptr native_runner_factory_; std::vector> native_runners_; base::WeakPtrFactory weak_ptr_factory_; DISALLOW_COPY_AND_ASSIGN(ApplicationManager); }; mojom::Shell::ConnectToApplicationCallback EmptyConnectCallback(); } // namespace shell } // namespace mojo #endif // MOJO_SHELL_APPLICATION_MANAGER_H_