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

Unified Diff: mojo/package_manager/package_manager_impl.h

Issue 1566253002: Move package_manager into mojo/shell (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: . Created 4 years, 11 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « mojo/package_manager/content_handler_unittest.cc ('k') | mojo/package_manager/package_manager_impl.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: mojo/package_manager/package_manager_impl.h
diff --git a/mojo/package_manager/package_manager_impl.h b/mojo/package_manager/package_manager_impl.h
deleted file mode 100644
index 3001fe33f6ee3ea26efe45dba73273176c4e253c..0000000000000000000000000000000000000000
--- a/mojo/package_manager/package_manager_impl.h
+++ /dev/null
@@ -1,113 +0,0 @@
-// Copyright 2015 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_PACKAGE_MANAGER_PACKAGE_MANAGER_IMPL_H_
-#define MOJO_PACKAGE_MANAGER_PACKAGE_MANAGER_IMPL_H_
-
-#include <stdint.h>
-
-#include "base/files/file_path.h"
-#include "base/macros.h"
-#include "mojo/fetcher/url_resolver.h"
-#include "mojo/services/network/public/interfaces/network_service.mojom.h"
-#include "mojo/services/network/public/interfaces/url_loader_factory.mojom.h"
-#include "mojo/shell/package_manager.h"
-
-namespace base {
-class TaskRunner;
-}
-
-namespace mojo {
-class ContentHandler;
-namespace shell {
-class Fetcher;
-class Identity;
-}
-namespace package_manager {
-class ContentHandlerConnection;
-
-// This is the default implementation of shell::PackageManager. It loads
-// http/s urls off the network as well as providing special handling for mojo:
-// and about: urls.
-class PackageManagerImpl : public shell::PackageManager {
- public:
- // mojo: urls are only supported if |shell_file_root| is non-empty.
- // |task_runner| is used by Fetchers created by the PackageManager to complete
- // file copies needed to obtain library paths that the ApplicationManager can
- // load. This can be null only in tests where application loading is handled
- // by custom ApplicationLoader implementations.
- PackageManagerImpl(const base::FilePath& shell_file_root,
- base::TaskRunner* task_runner);
- ~PackageManagerImpl() override;
-
- // Register a content handler to handle content of |mime_type|.
- void RegisterContentHandler(const std::string& mime_type,
- const GURL& content_handler_url);
-
- // Registers a package alias. When attempting to load |alias|, it will
- // instead redirect to |content_handler_package|, which is a content handler
- // which will be passed the |alias| as the URLResponse::url. Different values
- // of |alias| with the same |qualifier| that are in the same
- // |content_handler_package| will run in the same process in multi-process
- // mode.
- void RegisterApplicationPackageAlias(
- const GURL& alias,
- const GURL& content_handler_package,
- const std::string& qualifier);
-
- private:
- using ApplicationPackagedAlias = std::map<GURL, std::pair<GURL, std::string>>;
- using MimeTypeToURLMap = std::map<std::string, GURL>;
- using IdentityToContentHandlerMap =
- std::map<shell::Identity, ContentHandlerConnection*>;
-
- // Overridden from shell::PackageManager:
- void SetApplicationManager(shell::ApplicationManager* manager) override;
- void FetchRequest(
- URLRequestPtr request,
- const shell::Fetcher::FetchCallback& loader_callback) override;
- uint32_t HandleWithContentHandler(
- shell::Fetcher* fetcher,
- const shell::Identity& source,
- const GURL& target_url,
- const shell::CapabilityFilter& target_filter,
- InterfaceRequest<Application>* application_request) override;
-
- GURL ResolveURL(const GURL& url);
- bool ShouldHandleWithContentHandler(
- shell::Fetcher* fetcher,
- const GURL& target_url,
- const shell::CapabilityFilter& target_filter,
- shell::Identity* content_handler_identity,
- URLResponsePtr* response) const;
-
- // Returns a running ContentHandler for |content_handler_identity|, if there
- // is not one running one is started for |source_identity|.
- ContentHandlerConnection* GetContentHandler(
- const shell::Identity& content_handler_identity,
- const shell::Identity& source_identity);
-
- void OnContentHandlerConnectionClosed(
- ContentHandlerConnection* content_handler);
-
- shell::ApplicationManager* application_manager_;
- scoped_ptr<fetcher::URLResolver> url_resolver_;
- const bool disable_cache_;
- NetworkServicePtr network_service_;
- URLLoaderFactoryPtr url_loader_factory_;
- ApplicationPackagedAlias application_package_alias_;
- MimeTypeToURLMap mime_type_to_url_;
- IdentityToContentHandlerMap identity_to_content_handler_;
- // Counter used to assign ids to content handlers.
- uint32_t content_handler_id_counter_;
- base::TaskRunner* task_runner_;
- base::FilePath shell_file_root_;
-
- DISALLOW_COPY_AND_ASSIGN(PackageManagerImpl);
-};
-
-} // namespace package_manager
-} // namespace mojo
-
-#endif // MOJO_PACKAGE_MANAGER_PACKAGE_MANAGER_IMPL_H_
« no previous file with comments | « mojo/package_manager/content_handler_unittest.cc ('k') | mojo/package_manager/package_manager_impl.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698