1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef MOJO_SERVICE_MANAGER_SERVICE_MANAGER_H_
6 #define MOJO_SERVICE_MANAGER_SERVICE_MANAGER_H_
10 #include "base/basictypes.h"
11 #include "base/gtest_prod_util.h"
12 #include "base/memory/scoped_ptr.h"
13 #include "mojo/public/interfaces/shell/shell.mojom.h"
14 #include "mojo/service_manager/service_loader.h"
15 #include "mojo/service_manager/service_manager_export.h"
20 class MOJO_SERVICE_MANAGER_EXPORT ServiceManager
{
23 class MOJO_SERVICE_MANAGER_EXPORT TestAPI
{
25 explicit TestAPI(ServiceManager
* manager
);
28 // Returns a handle to a unique shell instance.
29 ScopedMessagePipeHandle
GetShellHandle();
31 // Returns true if the shared instance has been created.
32 static bool HasCreatedInstance();
33 // Returns true if there is a ServiceFactory for this URL.
34 bool HasFactoryForURL(const GURL
& url
) const;
37 class TestShellConnection
;
39 ServiceManager
* manager_
;
40 scoped_ptr
<TestShellConnection
> shell_
;
42 DISALLOW_COPY_AND_ASSIGN(TestAPI
);
45 // Interface class for debugging only.
48 virtual ~Interceptor() {}
49 // Called when ServiceManager::Connect is called.
50 virtual ScopedMessagePipeHandle
OnConnectToClient(
51 const GURL
& url
, ScopedMessagePipeHandle handle
) = 0;
57 // Returns a shared instance, creating it if necessary.
58 static ServiceManager
* GetInstance();
60 // Loads a service if necessary and establishes a new client connection.
61 void Connect(const GURL
& url
, ScopedMessagePipeHandle client_handle
);
63 // Sets the default Loader to be used if not overridden by SetLoaderForURL()
64 // or SetLoaderForScheme().
65 void set_default_loader(scoped_ptr
<ServiceLoader
> loader
) {
66 default_loader_
= loader
.Pass();
68 // Sets a Loader to be used for a specific url.
69 void SetLoaderForURL(scoped_ptr
<ServiceLoader
> loader
, const GURL
& url
);
70 // Sets a Loader to be used for a specific url scheme.
71 void SetLoaderForScheme(scoped_ptr
<ServiceLoader
> loader
,
72 const std::string
& scheme
);
73 // Allows to interpose a debugger to service connections.
74 void SetInterceptor(Interceptor
* interceptor
);
78 typedef std::map
<std::string
, ServiceLoader
*> SchemeToLoaderMap
;
79 typedef std::map
<GURL
, ServiceLoader
*> URLToLoaderMap
;
80 typedef std::map
<GURL
, ServiceFactory
*> URLToServiceFactoryMap
;
82 // Returns the Loader to use for a url (using default if not overridden.)
83 // The preference is to use a loader that's been specified for an url first,
84 // then one that's been specified for a scheme, then the default.
85 ServiceLoader
* GetLoaderForURL(const GURL
& url
);
87 // Removes a ServiceFactory when it encounters an error.
88 void OnServiceFactoryError(ServiceFactory
* service_factory
);
91 URLToLoaderMap url_to_loader_
;
92 SchemeToLoaderMap scheme_to_loader_
;
93 scoped_ptr
<ServiceLoader
> default_loader_
;
94 Interceptor
* interceptor_
;
96 URLToServiceFactoryMap url_to_service_factory_
;
97 DISALLOW_COPY_AND_ASSIGN(ServiceManager
);
102 #endif // MOJO_SERVICE_MANAGER_SERVICE_MANAGER_H_