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

Side by Side Diff: mojo/shell/content_handler_connection.h

Issue 1311353005: Adds a way to determine id of content handler that created app (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: tweaks Created 5 years, 3 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 unified diff | Download patch
OLDNEW
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 #ifndef MOJO_SHELL_CONTENT_HANDLER_CONNECTION_H_ 5 #ifndef MOJO_SHELL_CONTENT_HANDLER_CONNECTION_H_
6 #define MOJO_SHELL_CONTENT_HANDLER_CONNECTION_H_ 6 #define MOJO_SHELL_CONTENT_HANDLER_CONNECTION_H_
7 7
8 #include <string> 8 #include <string>
9 9
10 #include "base/memory/weak_ptr.h"
10 #include "mojo/application/public/interfaces/content_handler.mojom.h" 11 #include "mojo/application/public/interfaces/content_handler.mojom.h"
12 #include "mojo/application/public/interfaces/shell.mojom.h"
11 #include "mojo/shell/capability_filter.h" 13 #include "mojo/shell/capability_filter.h"
12 #include "url/gurl.h" 14 #include "url/gurl.h"
13 15
14 namespace mojo { 16 namespace mojo {
15 namespace shell { 17 namespace shell {
16 18
17 class ApplicationInstance; 19 class ApplicationInstance;
18 class ApplicationManager; 20 class ApplicationManager;
19 21
20 // A ContentHandlerConnection is responsible for creating and maintaining a 22 // A ContentHandlerConnection is responsible for creating and maintaining a
21 // connection to an app which provides the ContentHandler service. 23 // connection to an app which provides the ContentHandler service.
22 // A ContentHandlerConnection can only be destroyed via CloseConnection. 24 // A ContentHandlerConnection can only be destroyed via CloseConnection.
23 // A ContentHandlerConnection manages its own lifetime and cannot be used with 25 // A ContentHandlerConnection manages its own lifetime and cannot be used with
24 // a scoped_ptr to avoid reentrant calls into ApplicationManager late in 26 // a scoped_ptr to avoid reentrant calls into ApplicationManager late in
25 // destruction. 27 // destruction.
26 class ContentHandlerConnection { 28 class ContentHandlerConnection {
27 public: 29 public:
30 // |id| is a unique identifier for this content handler.
28 ContentHandlerConnection(ApplicationInstance* originator, 31 ContentHandlerConnection(ApplicationInstance* originator,
29 ApplicationManager* manager, 32 ApplicationManager* manager,
30 const GURL& content_handler_url, 33 const GURL& content_handler_url,
31 const GURL& requestor_url, 34 const GURL& requestor_url,
32 const std::string& qualifier, 35 const std::string& qualifier,
33 const CapabilityFilter& filter); 36 const CapabilityFilter& filter,
37 uint32_t id);
34 38
35 // Closes the connection and destroys |this| object. 39 // Closes the connection and destroys |this| object.
36 void CloseConnection(); 40 void CloseConnection();
37 41
38 ContentHandler* content_handler() { return content_handler_.get(); } 42 ContentHandler* content_handler() { return content_handler_.get(); }
39 const GURL& content_handler_url() { return content_handler_url_; } 43 const GURL& content_handler_url() { return content_handler_url_; }
40 const std::string& content_handler_qualifier() { 44 const std::string& content_handler_qualifier() {
41 return content_handler_qualifier_; 45 return content_handler_qualifier_;
42 } 46 }
47 uint32_t id() const { return id_; }
48
49 // Schedules a callback to be run once the id of any nested content handlers
50 // are obtained.
51 void ScheduleTargetIdCallback(
Ben Goodger (Google) 2015/08/31 17:41:07 rename?
sky 2015/08/31 19:46:07 This was all nuked.
52 const Shell::ConnectToApplicationCallback& connect_callback);
43 53
44 private: 54 private:
45 ~ContentHandlerConnection(); 55 ~ContentHandlerConnection();
46 56
57 // Callback from ConnectToApplication() on the target application.
58 void OnGotNestedContentHandlerID(uint32_t content_handler_id);
59
60 // Returns the id to supply to the callback from
61 // Shell::ConnectToApplication(). The returned id is either the id of this
62 // content handler, or if connecting to the application involved another
63 // content handler, then the deepest id from that connection.
64 //
65 // This is only valid once OnGotNestedContentHandlerID() is received.
66 uint32_t content_handler_id_for_callback() const;
67
47 ApplicationManager* manager_; 68 ApplicationManager* manager_;
48 GURL content_handler_url_; 69 GURL content_handler_url_;
49 std::string content_handler_qualifier_; 70 std::string content_handler_qualifier_;
50 ContentHandlerPtr content_handler_; 71 ContentHandlerPtr content_handler_;
51 bool connection_closed_; 72 bool connection_closed_;
73 // The id for this content handler.
74 const uint32_t id_;
75
76 // Set to true once OnGotNestedContentHandlerID() has been invoked. At this
77 // point |nested_content_handler_id_| is valid.
78 bool got_nested_content_handler_id_;
79 uint32_t nested_content_handler_id_;
80
81 // Callbacks scheduled before OnGotNestedContentHandlerID() are added here.
82 // Once OnGotNestedContentHandlerID() is called these are processed.
83 std::vector<Shell::ConnectToApplicationCallback>
84 pending_content_handler_id_callbacks_;
85
86 base::WeakPtrFactory<ContentHandlerConnection> weak_ptr_factory_;
52 87
53 DISALLOW_COPY_AND_ASSIGN(ContentHandlerConnection); 88 DISALLOW_COPY_AND_ASSIGN(ContentHandlerConnection);
54 }; 89 };
55 90
56 } // namespace shell 91 } // namespace shell
57 } // namespace mojo 92 } // namespace mojo
58 93
59 #endif // MOJO_SHELL_CONTENT_HANDLER_CONNECTION_H_ 94 #endif // MOJO_SHELL_CONTENT_HANDLER_CONNECTION_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698