OLD | NEW |
---|---|
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 #include "blimp/net/blimp_connection.h" | 5 #include "blimp/net/blimp_connection.h" |
6 | 6 |
7 #include <utility> | 7 #include <utility> |
8 | 8 |
9 #include "base/callback_helpers.h" | 9 #include "base/callback_helpers.h" |
10 #include "base/logging.h" | 10 #include "base/logging.h" |
11 #include "base/macros.h" | 11 #include "base/macros.h" |
12 #include "base/memory/weak_ptr.h" | 12 #include "base/memory/weak_ptr.h" |
13 #include "base/message_loop/message_loop.h" | 13 #include "base/message_loop/message_loop.h" |
14 #include "blimp/common/create_blimp_message.h" | 14 #include "blimp/common/create_blimp_message.h" |
15 #include "blimp/common/logging.h" | 15 #include "blimp/common/logging.h" |
16 #include "blimp/common/proto/blimp_message.pb.h" | 16 #include "blimp/common/proto/blimp_message.pb.h" |
17 #include "blimp/net/blimp_message_processor.h" | 17 #include "blimp/net/blimp_message_processor.h" |
18 #include "blimp/net/blimp_message_pump.h" | 18 #include "blimp/net/blimp_message_pump.h" |
19 #include "blimp/net/common.h" | 19 #include "blimp/net/common.h" |
20 #include "blimp/net/connection_error_observer.h" | 20 #include "blimp/net/connection_error_observer.h" |
21 #include "blimp/net/message_port.h" | 21 #include "blimp/net/message_port.h" |
22 #include "blimp/net/packet_writer.h" | 22 #include "blimp/net/packet_writer.h" |
23 #include "net/base/completion_callback.h" | 23 #include "net/base/completion_callback.h" |
24 | 24 |
25 namespace blimp { | 25 namespace blimp { |
26 | 26 |
27 // Forwards incoming blimp messages to PacketWriter. | |
28 class BlimpMessageSender : public BlimpMessageProcessor { | |
29 public: | |
30 explicit BlimpMessageSender(PacketWriter* writer); | |
31 ~BlimpMessageSender() override; | |
32 | |
33 void set_error_observer(ConnectionErrorObserver* observer) { | |
34 error_observer_ = observer; | |
35 } | |
36 | |
37 // BlimpMessageProcessor implementation. | |
38 // |callback| receives net::OK on write success, or receives an error code | |
39 // otherwise. | |
40 void ProcessMessage(std::unique_ptr<BlimpMessage> message, | |
41 const net::CompletionCallback& callback) override; | |
42 | |
43 private: | |
44 void OnWritePacketComplete(int result); | |
45 | |
46 PacketWriter* writer_; | |
47 ConnectionErrorObserver* error_observer_ = nullptr; | |
48 scoped_refptr<net::IOBuffer> buffer_; | |
49 net::CompletionCallback pending_process_msg_callback_; | |
50 base::WeakPtrFactory<BlimpMessageSender> weak_factory_; | |
51 | |
52 DISALLOW_COPY_AND_ASSIGN(BlimpMessageSender); | |
53 }; | |
54 | |
55 BlimpMessageSender::BlimpMessageSender(PacketWriter* writer) | |
56 : writer_(writer), | |
57 buffer_(new net::IOBuffer(kMaxPacketPayloadSizeBytes)), | |
58 weak_factory_(this) { | |
59 DCHECK(writer_); | |
60 } | |
61 | |
62 BlimpMessageSender::~BlimpMessageSender() { | |
63 DVLOG(1) << "BlimpMessageSender destroyed."; | |
64 } | |
65 | |
66 void BlimpMessageSender::ProcessMessage( | |
67 std::unique_ptr<BlimpMessage> message, | |
68 const net::CompletionCallback& callback) { | |
69 DCHECK(error_observer_); | |
70 VLOG(1) << "Sending " << *message; | |
71 | |
72 if (message->ByteSize() > static_cast<int>(kMaxPacketPayloadSizeBytes)) { | |
73 DLOG(ERROR) << "Message rejected (too large): " << *message; | |
74 callback.Run(net::ERR_MSG_TOO_BIG); | |
75 return; | |
76 } | |
77 if (!message->SerializeToArray(buffer_->data(), message->GetCachedSize())) { | |
78 DLOG(ERROR) << "Failed to serialize message."; | |
79 callback.Run(net::ERR_INVALID_ARGUMENT); | |
80 return; | |
81 } | |
82 | |
83 // Check that no other message writes are in-flight at this time. | |
84 DCHECK(pending_process_msg_callback_.is_null()); | |
85 pending_process_msg_callback_ = callback; | |
86 | |
87 writer_->WritePacket( | |
88 scoped_refptr<net::DrainableIOBuffer>( | |
89 new net::DrainableIOBuffer(buffer_.get(), message->ByteSize())), | |
90 base::Bind(&BlimpMessageSender::OnWritePacketComplete, | |
91 weak_factory_.GetWeakPtr())); | |
92 } | |
93 | |
94 void BlimpMessageSender::OnWritePacketComplete(int result) { | |
95 DVLOG(2) << "OnWritePacketComplete, result=" << result; | |
96 DCHECK_NE(net::ERR_IO_PENDING, result); | |
97 | |
98 // Create a stack-local copy of |pending_process_msg_callback_|, in case an | |
99 // observer deletes |this|. | |
100 net::CompletionCallback process_callback = | |
101 base::ResetAndReturn(&pending_process_msg_callback_); | |
102 | |
103 if (result != net::OK) { | |
104 error_observer_->OnConnectionError(result); | |
105 } | |
106 | |
107 process_callback.Run(result); | |
108 } | |
109 | |
110 // MessageProcessor filter used to route EndConnection messages through to | 27 // MessageProcessor filter used to route EndConnection messages through to |
111 // OnConnectionError notifications on the owning BlimpConnection. | 28 // OnConnectionError notifications on the owning BlimpConnection. |
112 class BlimpConnection::EndConnectionFilter : public BlimpMessageProcessor { | 29 class BlimpConnection::EndConnectionFilter : public BlimpMessageProcessor { |
113 public: | 30 public: |
114 explicit EndConnectionFilter(BlimpConnection* connection); | 31 explicit EndConnectionFilter(BlimpConnection* connection); |
115 | 32 |
116 void set_message_handler(BlimpMessageProcessor* message_handler) { | 33 void set_message_handler(BlimpMessageProcessor* message_handler) { |
117 message_handler_ = message_handler; | 34 message_handler_ = message_handler; |
118 } | 35 } |
119 | 36 |
(...skipping 25 matching lines...) Expand all Loading... | |
145 message->protocol_control().end_connection().reason()); | 62 message->protocol_control().end_connection().reason()); |
146 | 63 |
147 // Caller must ensure |callback| safe to call after OnConnectionError. | 64 // Caller must ensure |callback| safe to call after OnConnectionError. |
148 callback.Run(message->protocol_control().end_connection().reason()); | 65 callback.Run(message->protocol_control().end_connection().reason()); |
149 return; | 66 return; |
150 } | 67 } |
151 | 68 |
152 message_handler_->ProcessMessage(std::move(message), callback); | 69 message_handler_->ProcessMessage(std::move(message), callback); |
153 } | 70 } |
154 | 71 |
155 BlimpConnection::BlimpConnection(std::unique_ptr<MessagePort> message_port) | 72 BlimpConnection::BlimpConnection() |
156 : message_port_(std::move(message_port)), | 73 : end_connection_filter_(new EndConnectionFilter(this)) {} |
157 message_pump_(new BlimpMessagePump(message_port_->reader())), | |
158 outgoing_msg_processor_(new BlimpMessageSender(message_port_->writer())), | |
159 end_connection_filter_(new EndConnectionFilter(this)) { | |
160 message_pump_->set_error_observer(this); | |
161 outgoing_msg_processor_->set_error_observer(this); | |
162 } | |
163 | |
164 BlimpConnection::BlimpConnection() {} | |
165 | 74 |
166 BlimpConnection::~BlimpConnection() { | 75 BlimpConnection::~BlimpConnection() { |
167 VLOG(1) << "BlimpConnection destroyed."; | 76 VLOG(1) << "BlimpConnection destroyed."; |
168 } | 77 } |
169 | 78 |
170 void BlimpConnection::AddConnectionErrorObserver( | 79 void BlimpConnection::AddConnectionErrorObserver( |
171 ConnectionErrorObserver* observer) { | 80 ConnectionErrorObserver* observer) { |
172 error_observers_.AddObserver(observer); | 81 error_observers_.AddObserver(observer); |
173 } | 82 } |
174 | 83 |
175 void BlimpConnection::RemoveConnectionErrorObserver( | 84 void BlimpConnection::RemoveConnectionErrorObserver( |
176 ConnectionErrorObserver* observer) { | 85 ConnectionErrorObserver* observer) { |
177 error_observers_.RemoveObserver(observer); | 86 error_observers_.RemoveObserver(observer); |
178 } | 87 } |
179 | 88 |
180 void BlimpConnection::SetIncomingMessageProcessor( | 89 void BlimpConnection::AddEndConnectionProcessor( |
181 BlimpMessageProcessor* processor) { | 90 BlimpMessageProcessor* processor) { |
182 end_connection_filter_->set_message_handler(processor); | 91 end_connection_filter_->set_message_handler(processor); |
183 message_pump_->SetMessageProcessor(processor ? end_connection_filter_.get() | |
184 : nullptr); | |
185 } | 92 } |
186 | 93 |
187 BlimpMessageProcessor* BlimpConnection::GetOutgoingMessageProcessor() { | 94 BlimpMessageProcessor* BlimpConnection::GetEndConnectionProcessor() const { |
188 return outgoing_msg_processor_.get(); | 95 return end_connection_filter_.get(); |
Wez
2016/11/09 22:47:17
This isn't symmetric with AddEndConnectionProcesso
| |
189 } | 96 } |
190 | 97 |
191 void BlimpConnection::OnConnectionError(int error) { | 98 void BlimpConnection::OnConnectionError(int error) { |
192 VLOG(1) << "OnConnectionError, error=" << error; | 99 VLOG(1) << "OnConnectionError, error=" << error; |
193 | 100 |
194 // Propagate the error to all observers. | 101 // Propagate the error to all observers. |
195 for (auto& observer : error_observers_) | 102 for (auto& observer : error_observers_) { |
196 observer.OnConnectionError(error); | 103 observer.OnConnectionError(error); |
104 } | |
197 } | 105 } |
198 | 106 |
199 } // namespace blimp | 107 } // namespace blimp |
OLD | NEW |