OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2012 The WebRTC Project Authors. All rights reserved. | 2 * Copyright 2012 The WebRTC Project Authors. All rights reserved. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license | 4 * Use of this source code is governed by a BSD-style license |
5 * that can be found in the LICENSE file in the root of the source | 5 * that can be found in the LICENSE file in the root of the source |
6 * tree. An additional intellectual property rights grant can be found | 6 * tree. An additional intellectual property rights grant can be found |
7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
9 */ | 9 */ |
10 | 10 |
(...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
71 virtual Connection* CreateConnection( | 71 virtual Connection* CreateConnection( |
72 const Candidate& remote_candidate, CandidateOrigin origin) = 0; | 72 const Candidate& remote_candidate, CandidateOrigin origin) = 0; |
73 | 73 |
74 // Functions on the underlying socket(s). | 74 // Functions on the underlying socket(s). |
75 virtual int SetOption(rtc::Socket::Option opt, int value) = 0; | 75 virtual int SetOption(rtc::Socket::Option opt, int value) = 0; |
76 virtual int GetOption(rtc::Socket::Option opt, int* value) = 0; | 76 virtual int GetOption(rtc::Socket::Option opt, int* value) = 0; |
77 virtual int GetError() = 0; | 77 virtual int GetError() = 0; |
78 | 78 |
79 virtual const std::vector<Candidate>& Candidates() const = 0; | 79 virtual const std::vector<Candidate>& Candidates() const = 0; |
80 | 80 |
| 81 // A port is closed when it is not actively used. A closed port will not be |
| 82 // used to create connections except when it receives stun requests from |
| 83 // unknown addresses, although the connections on it may still be used. |
| 84 virtual void Close() = 0; |
| 85 |
81 // Sends the given packet to the given address, provided that the address is | 86 // Sends the given packet to the given address, provided that the address is |
82 // that of a connection or an address that has sent to us already. | 87 // that of a connection or an address that has sent to us already. |
83 virtual int SendTo(const void* data, size_t size, | 88 virtual int SendTo(const void* data, size_t size, |
84 const rtc::SocketAddress& addr, | 89 const rtc::SocketAddress& addr, |
85 const rtc::PacketOptions& options, bool payload) = 0; | 90 const rtc::PacketOptions& options, bool payload) = 0; |
86 | 91 |
87 // Indicates that we received a successful STUN binding request from an | 92 // Indicates that we received a successful STUN binding request from an |
88 // address that doesn't correspond to any current connection. To turn this | 93 // address that doesn't correspond to any current connection. To turn this |
89 // into a real connection, call CreateConnection. | 94 // into a real connection, call CreateConnection. |
90 sigslot::signal6<PortInterface*, const rtc::SocketAddress&, | 95 sigslot::signal6<PortInterface*, const rtc::SocketAddress&, |
91 ProtocolType, IceMessage*, const std::string&, | 96 ProtocolType, IceMessage*, const std::string&, |
92 bool> SignalUnknownAddress; | 97 bool> SignalUnknownAddress; |
93 | 98 |
94 // Sends a response message (normal or error) to the given request. One of | 99 // Sends a response message (normal or error) to the given request. One of |
95 // these methods should be called as a response to SignalUnknownAddress. | 100 // these methods should be called as a response to SignalUnknownAddress. |
96 // NOTE: You MUST call CreateConnection BEFORE SendBindingResponse. | 101 // NOTE: You MUST call CreateConnection BEFORE SendBindingResponse. |
97 virtual void SendBindingResponse(StunMessage* request, | 102 virtual void SendBindingResponse(StunMessage* request, |
98 const rtc::SocketAddress& addr) = 0; | 103 const rtc::SocketAddress& addr) = 0; |
99 virtual void SendBindingErrorResponse( | 104 virtual void SendBindingErrorResponse( |
100 StunMessage* request, const rtc::SocketAddress& addr, | 105 StunMessage* request, const rtc::SocketAddress& addr, |
101 int error_code, const std::string& reason) = 0; | 106 int error_code, const std::string& reason) = 0; |
102 | 107 |
103 // Signaled when this port decides to delete itself because it no longer has | 108 // Signaled when this port decides to delete itself because it no longer has |
104 // any usefulness. | 109 // any usefulness. |
105 sigslot::signal1<PortInterface*> SignalDestroyed; | 110 sigslot::signal1<PortInterface*> SignalDestroyed; |
106 | 111 |
107 // Signaled when the network used by this port becomes inactive. | 112 // A closed port will not be used to create new connections except when |
108 sigslot::signal1<PortInterface*> SignalNetworkInactive; | 113 // receiving stun ping from unknown address. |
| 114 sigslot::signal1<PortInterface*> SignalClosed; |
109 | 115 |
110 // Signaled when Port discovers ice role conflict with the peer. | 116 // Signaled when Port discovers ice role conflict with the peer. |
111 sigslot::signal1<PortInterface*> SignalRoleConflict; | 117 sigslot::signal1<PortInterface*> SignalRoleConflict; |
112 | 118 |
113 // Normally, packets arrive through a connection (or they result signaling of | 119 // Normally, packets arrive through a connection (or they result signaling of |
114 // unknown address). Calling this method turns off delivery of packets | 120 // unknown address). Calling this method turns off delivery of packets |
115 // through their respective connection and instead delivers every packet | 121 // through their respective connection and instead delivers every packet |
116 // through this port. | 122 // through this port. |
117 virtual void EnablePortPackets() = 0; | 123 virtual void EnablePortPackets() = 0; |
118 sigslot::signal4<PortInterface*, const char*, size_t, | 124 sigslot::signal4<PortInterface*, const char*, size_t, |
119 const rtc::SocketAddress&> SignalReadPacket; | 125 const rtc::SocketAddress&> SignalReadPacket; |
120 | 126 |
121 // Emitted each time a packet is sent on this port. | 127 // Emitted each time a packet is sent on this port. |
122 sigslot::signal1<const rtc::SentPacket&> SignalSentPacket; | 128 sigslot::signal1<const rtc::SentPacket&> SignalSentPacket; |
123 | 129 |
124 virtual std::string ToString() const = 0; | 130 virtual std::string ToString() const = 0; |
125 | 131 |
| 132 virtual void FailAndDestroyConnections() = 0; |
| 133 |
126 protected: | 134 protected: |
127 PortInterface() {} | 135 PortInterface() {} |
128 }; | 136 }; |
129 | 137 |
130 } // namespace cricket | 138 } // namespace cricket |
131 | 139 |
132 #endif // WEBRTC_P2P_BASE_PORTINTERFACE_H_ | 140 #endif // WEBRTC_P2P_BASE_PORTINTERFACE_H_ |
OLD | NEW |