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
3 // found in the LICENSE file.
5 #ifndef MOJO_SHELL_CONNECT_TO_APPLICATION_PARAMS_H_
6 #define MOJO_SHELL_CONNECT_TO_APPLICATION_PARAMS_H_
10 #include "base/callback.h"
11 #include "mojo/application/public/interfaces/service_provider.mojom.h"
12 #include "mojo/application/public/interfaces/shell.mojom.h"
13 #include "mojo/public/cpp/bindings/interface_request.h"
14 #include "mojo/services/network/public/interfaces/url_loader.mojom.h"
15 #include "mojo/shell/capability_filter.h"
16 #include "mojo/shell/identity.h"
22 class ApplicationInstance
;
24 // This class represents a request for the application manager to connect to an
26 class ConnectToApplicationParams
{
28 ConnectToApplicationParams();
29 ~ConnectToApplicationParams();
31 // Sets both |originator_identity_| and |originator_filter_|. If |originator|
32 // is null, both fields are reset.
33 void SetOriginatorInfo(ApplicationInstance
* originator
);
35 // Sets both |app_url_| and |app_url_request_|.
36 void SetURLInfo(const GURL
& app_url
);
37 // Sets both |app_url_| and |app_url_request_|.
38 void SetURLInfo(URLRequestPtr app_url_request
);
40 void set_originator_identity(const Identity
& value
) {
41 originator_identity_
= value
;
43 const Identity
& originator_identity() const { return originator_identity_
; }
45 void set_originator_filter(const CapabilityFilter
& value
) {
46 originator_filter_
= value
;
48 const CapabilityFilter
& originator_filter() const {
49 return originator_filter_
;
52 const GURL
& app_url() const { return app_url_
; }
54 const URLRequest
* app_url_request() const { return app_url_request_
.get(); }
55 // NOTE: This doesn't reset |app_url_|.
56 URLRequestPtr
TakeAppURLRequest() { return app_url_request_
.Pass(); }
58 void set_qualifier(const std::string
& value
) { qualifier_
= value
; }
59 const std::string
& qualifier() const { return qualifier_
; }
61 void set_services(InterfaceRequest
<ServiceProvider
> value
) {
62 services_
= value
.Pass();
64 InterfaceRequest
<ServiceProvider
> TakeServices() { return services_
.Pass(); }
66 void set_exposed_services(ServiceProviderPtr value
) {
67 exposed_services_
= value
.Pass();
69 ServiceProviderPtr
TakeExposedServices() { return exposed_services_
.Pass(); }
71 void set_filter(const CapabilityFilter
& value
) { filter_
= value
; }
72 const CapabilityFilter
& filter() const { return filter_
; }
74 void set_on_application_end(const base::Closure
& value
) {
75 on_application_end_
= value
;
77 const base::Closure
& on_application_end() const {
78 return on_application_end_
;
81 void set_connect_callback(const Shell::ConnectToApplicationCallback
& value
) {
82 connect_callback_
= value
;
84 const Shell::ConnectToApplicationCallback
& connect_callback() const {
85 return connect_callback_
;
89 // It may be null (i.e., is_null() returns true) which indicates that there is
90 // no originator (e.g., for the first application or in tests).
91 Identity originator_identity_
;
92 // Should be ignored if |originator_identity_| is null.
93 CapabilityFilter originator_filter_
;
94 // The URL of the application that is being connected to.
96 // The URL request to fetch the application. It may contain more information
97 // than |app_url_| (e.g., headers, request body). When it is taken, |app_url_|
99 URLRequestPtr app_url_request_
;
100 // Please see the comments in identity.h for the exact meaning of qualifier.
101 std::string qualifier_
;
102 InterfaceRequest
<ServiceProvider
> services_
;
103 ServiceProviderPtr exposed_services_
;
104 CapabilityFilter filter_
;
105 base::Closure on_application_end_
;
106 Shell::ConnectToApplicationCallback connect_callback_
;
108 DISALLOW_COPY_AND_ASSIGN(ConnectToApplicationParams
);
114 #endif // MOJO_SHELL_CONNECT_TO_APPLICATION_PARAMS_H_