blob: 42493f9a44a4f65eafd73bf09b0bd88cca1474af (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
|
// Copyright (c) 2009 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef REMOTING_JINGLE_GLUE_XMPP_SOCKET_ADAPTER_H_
#define REMOTING_JINGLE_GLUE_XMPP_SOCKET_ADAPTER_H_
#include <string>
#include "third_party/libjingle/source/talk/base/asyncsocket.h"
#include "third_party/libjingle/source/talk/xmpp/asyncsocket.h"
#include "third_party/libjingle/source/talk/xmpp/xmppclientsettings.h"
#include "third_party/libjingle/source/talk/xmpp/xmppengine.h"
#ifndef _WIN32
// Additional errors used by us from Win32 headers.
#define SEC_E_CERT_EXPIRED static_cast<int>(0x80090328L)
#define WSA_NOT_ENOUGH_MEMORY ENOMEM
#endif
namespace remoting {
class XmppSocketAdapter : public buzz::AsyncSocket,
public sigslot::has_slots<> {
public:
XmppSocketAdapter(const buzz::XmppClientSettings& xcs,
bool allow_unverified_certs);
virtual ~XmppSocketAdapter();
virtual State state() { return state_; }
virtual Error error() { return error_; }
virtual int GetError() { return wsa_error_; }
void set_firewall(bool firewall) { firewall_ = firewall; }
virtual bool Connect(const talk_base::SocketAddress& addr);
virtual bool Read(char* data, size_t len, size_t* len_read);
virtual bool Write(const char* data, size_t len);
virtual bool Close();
#if defined(FEATURE_ENABLE_SSL)
virtual bool StartTls(const std::string& domainname);
bool IsOpen() const { return state_ == STATE_OPEN
|| state_ == STATE_TLS_OPEN; }
#else
bool IsOpen() const { return state_ == STATE_OPEN; }
#endif
sigslot::signal0<> SignalAuthenticationError;
private:
// Return false if the socket is closed.
bool HandleReadable();
bool HandleWritable();
State state_;
Error error_;
int wsa_error_;
talk_base::AsyncSocket* socket_;
cricket::ProtocolType protocol_;
talk_base::ProxyInfo proxy_;
bool firewall_;
char* write_buffer_;
size_t write_buffer_length_;
size_t write_buffer_capacity_;
bool allow_unverified_certs_;
bool FreeState();
void NotifyClose();
void OnReadEvent(talk_base::AsyncSocket* socket);
void OnWriteEvent(talk_base::AsyncSocket* socket);
void OnConnectEvent(talk_base::AsyncSocket* socket);
void OnCloseEvent(talk_base::AsyncSocket* socket, int error);
void QueueWriteData(const char* data, size_t len);
void FlushWriteQueue(Error* error, int* wsa_error);
void SetError(Error error);
void SetWSAError(int error);
DISALLOW_COPY_AND_ASSIGN(XmppSocketAdapter);
};
} // namespace remoting
#endif // REMOTING_JINGLE_GLUE_XMPP_SOCKET_ADAPTER_H_
|