OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 'use strict'; | 5 'use strict'; |
6 | 6 |
7 /** @suppress {duplicate} */ | 7 /** @suppress {duplicate} */ |
8 var remoting = remoting || {}; | 8 var remoting = remoting || {}; |
9 | 9 |
10 /** | 10 /** |
(...skipping 21 matching lines...) Expand all Loading... |
32 this.startTlsPending_ = false; | 32 this.startTlsPending_ = false; |
33 /** @private {Array<ArrayBuffer>} */ | 33 /** @private {Array<ArrayBuffer>} */ |
34 this.sendQueue_ = []; | 34 this.sendQueue_ = []; |
35 /** @private {remoting.XmppLoginHandler} */ | 35 /** @private {remoting.XmppLoginHandler} */ |
36 this.loginHandler_ = null; | 36 this.loginHandler_ = null; |
37 /** @private {remoting.XmppStreamParser} */ | 37 /** @private {remoting.XmppStreamParser} */ |
38 this.streamParser_ = null; | 38 this.streamParser_ = null; |
39 /** @private */ | 39 /** @private */ |
40 this.jid_ = ''; | 40 this.jid_ = ''; |
41 /** @private */ | 41 /** @private */ |
42 this.error_ = remoting.Error.NONE; | 42 this.error_ = remoting.Error.none(); |
43 }; | 43 }; |
44 | 44 |
45 /** | 45 /** |
46 * @param {function(remoting.SignalStrategy.State):void} onStateChangedCallback | 46 * @param {function(remoting.SignalStrategy.State):void} onStateChangedCallback |
47 */ | 47 */ |
48 remoting.XmppConnection.prototype.setStateChangedCallback = function( | 48 remoting.XmppConnection.prototype.setStateChangedCallback = function( |
49 onStateChangedCallback) { | 49 onStateChangedCallback) { |
50 this.onStateChangedCallback_ = onStateChangedCallback; | 50 this.onStateChangedCallback_ = onStateChangedCallback; |
51 }; | 51 }; |
52 | 52 |
(...skipping 14 matching lines...) Expand all Loading... |
67 /** | 67 /** |
68 * @param {string} server | 68 * @param {string} server |
69 * @param {string} username | 69 * @param {string} username |
70 * @param {string} authToken | 70 * @param {string} authToken |
71 */ | 71 */ |
72 remoting.XmppConnection.prototype.connect = | 72 remoting.XmppConnection.prototype.connect = |
73 function(server, username, authToken) { | 73 function(server, username, authToken) { |
74 base.debug.assert(this.state_ == remoting.SignalStrategy.State.NOT_CONNECTED); | 74 base.debug.assert(this.state_ == remoting.SignalStrategy.State.NOT_CONNECTED); |
75 base.debug.assert(this.onStateChangedCallback_ != null); | 75 base.debug.assert(this.onStateChangedCallback_ != null); |
76 | 76 |
77 this.error_ = remoting.Error.NONE; | 77 this.error_ = remoting.Error.none(); |
78 var hostnameAndPort = server.split(':', 2); | 78 var hostnameAndPort = server.split(':', 2); |
79 this.server_ = hostnameAndPort[0]; | 79 this.server_ = hostnameAndPort[0]; |
80 this.port_ = | 80 this.port_ = |
81 (hostnameAndPort.length == 2) ? parseInt(hostnameAndPort[1], 10) : 5222; | 81 (hostnameAndPort.length == 2) ? parseInt(hostnameAndPort[1], 10) : 5222; |
82 | 82 |
83 // The server name is passed as to attribute in the <stream>. When connecting | 83 // The server name is passed as to attribute in the <stream>. When connecting |
84 // to talk.google.com it affects the certificate the server will use for TLS: | 84 // to talk.google.com it affects the certificate the server will use for TLS: |
85 // talk.google.com uses gmail certificate when specified server is gmail.com | 85 // talk.google.com uses gmail certificate when specified server is gmail.com |
86 // or googlemail.com and google.com cert otherwise. In the same time it | 86 // or googlemail.com and google.com cert otherwise. In the same time it |
87 // doesn't accept talk.google.com as target server. Here we use google.com | 87 // doesn't accept talk.google.com as target server. Here we use google.com |
(...skipping 16 matching lines...) Expand all Loading... |
104 this.onHandshakeDone_.bind(this), this.onError_.bind(this)); | 104 this.onHandshakeDone_.bind(this), this.onError_.bind(this)); |
105 this.setState_(remoting.SignalStrategy.State.CONNECTING); | 105 this.setState_(remoting.SignalStrategy.State.CONNECTING); |
106 | 106 |
107 if (!this.socket_) { | 107 if (!this.socket_) { |
108 this.socket_ = new remoting.TcpSocket(); | 108 this.socket_ = new remoting.TcpSocket(); |
109 } | 109 } |
110 var that = this; | 110 var that = this; |
111 this.socket_.connect(this.server_, this.port_) | 111 this.socket_.connect(this.server_, this.port_) |
112 .then(this.onSocketConnected_.bind(this)) | 112 .then(this.onSocketConnected_.bind(this)) |
113 .catch(function(error) { | 113 .catch(function(error) { |
114 that.onError_(remoting.Error.NETWORK_FAILURE, | 114 that.onError_(new remoting.Error(remoting.Error.Tag.NETWORK_FAILURE), |
115 'Failed to connect to ' + that.server_ + ': ' + error); | 115 'Failed to connect to ' + that.server_ + ': ' + error); |
116 }); | 116 }); |
117 }; | 117 }; |
118 | 118 |
119 /** @param {string} message */ | 119 /** @param {string} message */ |
120 remoting.XmppConnection.prototype.sendMessage = function(message) { | 120 remoting.XmppConnection.prototype.sendMessage = function(message) { |
121 base.debug.assert(this.state_ == remoting.SignalStrategy.State.CONNECTED); | 121 base.debug.assert(this.state_ == remoting.SignalStrategy.State.CONNECTED); |
122 this.sendString_(message); | 122 this.sendString_(message); |
123 }; | 123 }; |
124 | 124 |
(...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
185 } else if (this.state_ == remoting.SignalStrategy.State.CONNECTED) { | 185 } else if (this.state_ == remoting.SignalStrategy.State.CONNECTED) { |
186 this.streamParser_.appendData(data); | 186 this.streamParser_.appendData(data); |
187 } | 187 } |
188 }; | 188 }; |
189 | 189 |
190 /** | 190 /** |
191 * @param {number} errorCode | 191 * @param {number} errorCode |
192 * @private | 192 * @private |
193 */ | 193 */ |
194 remoting.XmppConnection.prototype.onReceiveError_ = function(errorCode) { | 194 remoting.XmppConnection.prototype.onReceiveError_ = function(errorCode) { |
195 this.onError_(remoting.Error.NETWORK_FAILURE, | 195 this.onError_(new remoting.Error(remoting.Error.Tag.NETWORK_FAILURE), |
196 'Failed to receive from XMPP socket: ' + errorCode); | 196 'Failed to receive from XMPP socket: ' + errorCode); |
197 }; | 197 }; |
198 | 198 |
199 /** | 199 /** |
200 * @param {string} text | 200 * @param {string} text |
201 * @private | 201 * @private |
202 */ | 202 */ |
203 remoting.XmppConnection.prototype.sendString_ = function(text) { | 203 remoting.XmppConnection.prototype.sendString_ = function(text) { |
204 this.sendBuffer_(base.encodeUtf8(text)); | 204 this.sendBuffer_(base.encodeUtf8(text)); |
205 }; | 205 }; |
(...skipping 18 matching lines...) Expand all Loading... |
224 var that = this; | 224 var that = this; |
225 | 225 |
226 this.sendPending_ = true; | 226 this.sendPending_ = true; |
227 this.socket_.send(this.sendQueue_[0]) | 227 this.socket_.send(this.sendQueue_[0]) |
228 .then(function(/** number */ bytesSent) { | 228 .then(function(/** number */ bytesSent) { |
229 that.sendPending_ = false; | 229 that.sendPending_ = false; |
230 that.onSent_(bytesSent); | 230 that.onSent_(bytesSent); |
231 }) | 231 }) |
232 .catch(function(/** number */ error) { | 232 .catch(function(/** number */ error) { |
233 that.sendPending_ = false; | 233 that.sendPending_ = false; |
234 that.onError_(remoting.Error.NETWORK_FAILURE, | 234 that.onError_(new remoting.Error(remoting.Error.Tag.NETWORK_FAILURE), |
235 'TCP write failed with error ' + error); | 235 'TCP write failed with error ' + error); |
236 }); | 236 }); |
237 }; | 237 }; |
238 | 238 |
239 /** | 239 /** |
240 * @param {number} bytesSent | 240 * @param {number} bytesSent |
241 * @private | 241 * @private |
242 */ | 242 */ |
243 remoting.XmppConnection.prototype.onSent_ = function(bytesSent) { | 243 remoting.XmppConnection.prototype.onSent_ = function(bytesSent) { |
244 // Ignore send() result if the socket was closed. | 244 // Ignore send() result if the socket was closed. |
(...skipping 27 matching lines...) Expand all Loading... |
272 this.socket_.startTls() | 272 this.socket_.startTls() |
273 .then(function() { | 273 .then(function() { |
274 that.startTlsPending_ = false; | 274 that.startTlsPending_ = false; |
275 that.socket_.startReceiving(that.onReceive_.bind(that), | 275 that.socket_.startReceiving(that.onReceive_.bind(that), |
276 that.onReceiveError_.bind(that)); | 276 that.onReceiveError_.bind(that)); |
277 | 277 |
278 that.loginHandler_.onTlsStarted(); | 278 that.loginHandler_.onTlsStarted(); |
279 }) | 279 }) |
280 .catch(function(/** number */ error) { | 280 .catch(function(/** number */ error) { |
281 that.startTlsPending_ = false; | 281 that.startTlsPending_ = false; |
282 that.onError_(remoting.Error.NETWORK_FAILURE, | 282 that.onError_(new remoting.Error(remoting.Error.Tag.NETWORK_FAILURE), |
283 'Failed to start TLS: ' + error); | 283 'Failed to start TLS: ' + error); |
284 }); | 284 }); |
285 } | 285 } |
286 | 286 |
287 /** | 287 /** |
288 * @param {string} jid | 288 * @param {string} jid |
289 * @param {remoting.XmppStreamParser} streamParser | 289 * @param {remoting.XmppStreamParser} streamParser |
290 * @private | 290 * @private |
291 */ | 291 */ |
292 remoting.XmppConnection.prototype.onHandshakeDone_ = | 292 remoting.XmppConnection.prototype.onHandshakeDone_ = |
(...skipping 13 matching lines...) Expand all Loading... |
306 if (this.onIncomingStanzaCallback_) { | 306 if (this.onIncomingStanzaCallback_) { |
307 this.onIncomingStanzaCallback_(stanza); | 307 this.onIncomingStanzaCallback_(stanza); |
308 } | 308 } |
309 }; | 309 }; |
310 | 310 |
311 /** | 311 /** |
312 * @param {string} text | 312 * @param {string} text |
313 * @private | 313 * @private |
314 */ | 314 */ |
315 remoting.XmppConnection.prototype.onParserError_ = function(text) { | 315 remoting.XmppConnection.prototype.onParserError_ = function(text) { |
316 this.onError_(remoting.Error.UNEXPECTED, text); | 316 this.onError_(remoting.Error.unexpected(), text); |
317 } | 317 }; |
318 | 318 |
319 /** | 319 /** |
320 * @param {!remoting.Error} error | 320 * @param {!remoting.Error} error |
321 * @param {string} text | 321 * @param {string} text |
322 * @private | 322 * @private |
323 */ | 323 */ |
324 remoting.XmppConnection.prototype.onError_ = function(error, text) { | 324 remoting.XmppConnection.prototype.onError_ = function(error, text) { |
325 console.error(text); | 325 console.error(text); |
326 this.error_ = error; | 326 this.error_ = error; |
327 base.dispose(this.socket_); | 327 base.dispose(this.socket_); |
328 this.socket_ = null; | 328 this.socket_ = null; |
329 this.setState_(remoting.SignalStrategy.State.FAILED); | 329 this.setState_(remoting.SignalStrategy.State.FAILED); |
330 }; | 330 }; |
331 | 331 |
332 /** | 332 /** |
333 * @param {remoting.SignalStrategy.State} newState | 333 * @param {remoting.SignalStrategy.State} newState |
334 * @private | 334 * @private |
335 */ | 335 */ |
336 remoting.XmppConnection.prototype.setState_ = function(newState) { | 336 remoting.XmppConnection.prototype.setState_ = function(newState) { |
337 if (this.state_ != newState) { | 337 if (this.state_ != newState) { |
338 this.state_ = newState; | 338 this.state_ = newState; |
339 this.onStateChangedCallback_(this.state_); | 339 this.onStateChangedCallback_(this.state_); |
340 } | 340 } |
341 }; | 341 }; |
OLD | NEW |