xref: /aosp_15_r20/external/webrtc/p2p/base/port_interface.h (revision d9f758449e529ab9291ac668be2861e7a55c2422)
1*d9f75844SAndroid Build Coastguard Worker /*
2*d9f75844SAndroid Build Coastguard Worker  *  Copyright 2012 The WebRTC Project Authors. All rights reserved.
3*d9f75844SAndroid Build Coastguard Worker  *
4*d9f75844SAndroid Build Coastguard Worker  *  Use of this source code is governed by a BSD-style license
5*d9f75844SAndroid Build Coastguard Worker  *  that can be found in the LICENSE file in the root of the source
6*d9f75844SAndroid Build Coastguard Worker  *  tree. An additional intellectual property rights grant can be found
7*d9f75844SAndroid Build Coastguard Worker  *  in the file PATENTS.  All contributing project authors may
8*d9f75844SAndroid Build Coastguard Worker  *  be found in the AUTHORS file in the root of the source tree.
9*d9f75844SAndroid Build Coastguard Worker  */
10*d9f75844SAndroid Build Coastguard Worker 
11*d9f75844SAndroid Build Coastguard Worker #ifndef P2P_BASE_PORT_INTERFACE_H_
12*d9f75844SAndroid Build Coastguard Worker #define P2P_BASE_PORT_INTERFACE_H_
13*d9f75844SAndroid Build Coastguard Worker 
14*d9f75844SAndroid Build Coastguard Worker #include <string>
15*d9f75844SAndroid Build Coastguard Worker #include <utility>
16*d9f75844SAndroid Build Coastguard Worker #include <vector>
17*d9f75844SAndroid Build Coastguard Worker 
18*d9f75844SAndroid Build Coastguard Worker #include "absl/strings/string_view.h"
19*d9f75844SAndroid Build Coastguard Worker #include "absl/types/optional.h"
20*d9f75844SAndroid Build Coastguard Worker #include "api/candidate.h"
21*d9f75844SAndroid Build Coastguard Worker #include "p2p/base/transport_description.h"
22*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/async_packet_socket.h"
23*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/callback_list.h"
24*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/socket_address.h"
25*d9f75844SAndroid Build Coastguard Worker 
26*d9f75844SAndroid Build Coastguard Worker namespace rtc {
27*d9f75844SAndroid Build Coastguard Worker class Network;
28*d9f75844SAndroid Build Coastguard Worker struct PacketOptions;
29*d9f75844SAndroid Build Coastguard Worker }  // namespace rtc
30*d9f75844SAndroid Build Coastguard Worker 
31*d9f75844SAndroid Build Coastguard Worker namespace cricket {
32*d9f75844SAndroid Build Coastguard Worker class Connection;
33*d9f75844SAndroid Build Coastguard Worker class IceMessage;
34*d9f75844SAndroid Build Coastguard Worker class StunMessage;
35*d9f75844SAndroid Build Coastguard Worker class StunStats;
36*d9f75844SAndroid Build Coastguard Worker 
37*d9f75844SAndroid Build Coastguard Worker enum ProtocolType {
38*d9f75844SAndroid Build Coastguard Worker   PROTO_UDP,
39*d9f75844SAndroid Build Coastguard Worker   PROTO_TCP,
40*d9f75844SAndroid Build Coastguard Worker   PROTO_SSLTCP,  // Pseudo-TLS.
41*d9f75844SAndroid Build Coastguard Worker   PROTO_TLS,
42*d9f75844SAndroid Build Coastguard Worker   PROTO_LAST = PROTO_TLS
43*d9f75844SAndroid Build Coastguard Worker };
44*d9f75844SAndroid Build Coastguard Worker 
45*d9f75844SAndroid Build Coastguard Worker // Defines the interface for a port, which represents a local communication
46*d9f75844SAndroid Build Coastguard Worker // mechanism that can be used to create connections to similar mechanisms of
47*d9f75844SAndroid Build Coastguard Worker // the other client. Various types of ports will implement this interface.
48*d9f75844SAndroid Build Coastguard Worker class PortInterface {
49*d9f75844SAndroid Build Coastguard Worker  public:
50*d9f75844SAndroid Build Coastguard Worker   virtual ~PortInterface();
51*d9f75844SAndroid Build Coastguard Worker 
52*d9f75844SAndroid Build Coastguard Worker   virtual const std::string& Type() const = 0;
53*d9f75844SAndroid Build Coastguard Worker   virtual const rtc::Network* Network() const = 0;
54*d9f75844SAndroid Build Coastguard Worker 
55*d9f75844SAndroid Build Coastguard Worker   // Methods to set/get ICE role and tiebreaker values.
56*d9f75844SAndroid Build Coastguard Worker   virtual void SetIceRole(IceRole role) = 0;
57*d9f75844SAndroid Build Coastguard Worker   virtual IceRole GetIceRole() const = 0;
58*d9f75844SAndroid Build Coastguard Worker 
59*d9f75844SAndroid Build Coastguard Worker   virtual void SetIceTiebreaker(uint64_t tiebreaker) = 0;
60*d9f75844SAndroid Build Coastguard Worker   virtual uint64_t IceTiebreaker() const = 0;
61*d9f75844SAndroid Build Coastguard Worker 
62*d9f75844SAndroid Build Coastguard Worker   virtual bool SharedSocket() const = 0;
63*d9f75844SAndroid Build Coastguard Worker 
64*d9f75844SAndroid Build Coastguard Worker   virtual bool SupportsProtocol(absl::string_view protocol) const = 0;
65*d9f75844SAndroid Build Coastguard Worker 
66*d9f75844SAndroid Build Coastguard Worker   // PrepareAddress will attempt to get an address for this port that other
67*d9f75844SAndroid Build Coastguard Worker   // clients can send to.  It may take some time before the address is ready.
68*d9f75844SAndroid Build Coastguard Worker   // Once it is ready, we will send SignalAddressReady.  If errors are
69*d9f75844SAndroid Build Coastguard Worker   // preventing the port from getting an address, it may send
70*d9f75844SAndroid Build Coastguard Worker   // SignalAddressError.
71*d9f75844SAndroid Build Coastguard Worker   virtual void PrepareAddress() = 0;
72*d9f75844SAndroid Build Coastguard Worker 
73*d9f75844SAndroid Build Coastguard Worker   // Returns the connection to the given address or NULL if none exists.
74*d9f75844SAndroid Build Coastguard Worker   virtual Connection* GetConnection(const rtc::SocketAddress& remote_addr) = 0;
75*d9f75844SAndroid Build Coastguard Worker 
76*d9f75844SAndroid Build Coastguard Worker   // Creates a new connection to the given address.
77*d9f75844SAndroid Build Coastguard Worker   enum CandidateOrigin { ORIGIN_THIS_PORT, ORIGIN_OTHER_PORT, ORIGIN_MESSAGE };
78*d9f75844SAndroid Build Coastguard Worker   virtual Connection* CreateConnection(const Candidate& remote_candidate,
79*d9f75844SAndroid Build Coastguard Worker                                        CandidateOrigin origin) = 0;
80*d9f75844SAndroid Build Coastguard Worker 
81*d9f75844SAndroid Build Coastguard Worker   // Functions on the underlying socket(s).
82*d9f75844SAndroid Build Coastguard Worker   virtual int SetOption(rtc::Socket::Option opt, int value) = 0;
83*d9f75844SAndroid Build Coastguard Worker   virtual int GetOption(rtc::Socket::Option opt, int* value) = 0;
84*d9f75844SAndroid Build Coastguard Worker   virtual int GetError() = 0;
85*d9f75844SAndroid Build Coastguard Worker 
86*d9f75844SAndroid Build Coastguard Worker   virtual ProtocolType GetProtocol() const = 0;
87*d9f75844SAndroid Build Coastguard Worker 
88*d9f75844SAndroid Build Coastguard Worker   virtual const std::vector<Candidate>& Candidates() const = 0;
89*d9f75844SAndroid Build Coastguard Worker 
90*d9f75844SAndroid Build Coastguard Worker   // Sends the given packet to the given address, provided that the address is
91*d9f75844SAndroid Build Coastguard Worker   // that of a connection or an address that has sent to us already.
92*d9f75844SAndroid Build Coastguard Worker   virtual int SendTo(const void* data,
93*d9f75844SAndroid Build Coastguard Worker                      size_t size,
94*d9f75844SAndroid Build Coastguard Worker                      const rtc::SocketAddress& addr,
95*d9f75844SAndroid Build Coastguard Worker                      const rtc::PacketOptions& options,
96*d9f75844SAndroid Build Coastguard Worker                      bool payload) = 0;
97*d9f75844SAndroid Build Coastguard Worker 
98*d9f75844SAndroid Build Coastguard Worker   // Indicates that we received a successful STUN binding request from an
99*d9f75844SAndroid Build Coastguard Worker   // address that doesn't correspond to any current connection.  To turn this
100*d9f75844SAndroid Build Coastguard Worker   // into a real connection, call CreateConnection.
101*d9f75844SAndroid Build Coastguard Worker   sigslot::signal6<PortInterface*,
102*d9f75844SAndroid Build Coastguard Worker                    const rtc::SocketAddress&,
103*d9f75844SAndroid Build Coastguard Worker                    ProtocolType,
104*d9f75844SAndroid Build Coastguard Worker                    IceMessage*,
105*d9f75844SAndroid Build Coastguard Worker                    const std::string&,
106*d9f75844SAndroid Build Coastguard Worker                    bool>
107*d9f75844SAndroid Build Coastguard Worker       SignalUnknownAddress;
108*d9f75844SAndroid Build Coastguard Worker 
109*d9f75844SAndroid Build Coastguard Worker   // Sends a response message (normal or error) to the given request.  One of
110*d9f75844SAndroid Build Coastguard Worker   // these methods should be called as a response to SignalUnknownAddress.
111*d9f75844SAndroid Build Coastguard Worker   virtual void SendBindingErrorResponse(StunMessage* message,
112*d9f75844SAndroid Build Coastguard Worker                                         const rtc::SocketAddress& addr,
113*d9f75844SAndroid Build Coastguard Worker                                         int error_code,
114*d9f75844SAndroid Build Coastguard Worker                                         absl::string_view reason) = 0;
115*d9f75844SAndroid Build Coastguard Worker 
116*d9f75844SAndroid Build Coastguard Worker   // Signaled when this port decides to delete itself because it no longer has
117*d9f75844SAndroid Build Coastguard Worker   // any usefulness.
118*d9f75844SAndroid Build Coastguard Worker   virtual void SubscribePortDestroyed(
119*d9f75844SAndroid Build Coastguard Worker       std::function<void(PortInterface*)> callback) = 0;
120*d9f75844SAndroid Build Coastguard Worker 
121*d9f75844SAndroid Build Coastguard Worker   // Signaled when Port discovers ice role conflict with the peer.
122*d9f75844SAndroid Build Coastguard Worker   sigslot::signal1<PortInterface*> SignalRoleConflict;
123*d9f75844SAndroid Build Coastguard Worker 
124*d9f75844SAndroid Build Coastguard Worker   // Normally, packets arrive through a connection (or they result signaling of
125*d9f75844SAndroid Build Coastguard Worker   // unknown address).  Calling this method turns off delivery of packets
126*d9f75844SAndroid Build Coastguard Worker   // through their respective connection and instead delivers every packet
127*d9f75844SAndroid Build Coastguard Worker   // through this port.
128*d9f75844SAndroid Build Coastguard Worker   virtual void EnablePortPackets() = 0;
129*d9f75844SAndroid Build Coastguard Worker   sigslot::
130*d9f75844SAndroid Build Coastguard Worker       signal4<PortInterface*, const char*, size_t, const rtc::SocketAddress&>
131*d9f75844SAndroid Build Coastguard Worker           SignalReadPacket;
132*d9f75844SAndroid Build Coastguard Worker 
133*d9f75844SAndroid Build Coastguard Worker   // Emitted each time a packet is sent on this port.
134*d9f75844SAndroid Build Coastguard Worker   sigslot::signal1<const rtc::SentPacket&> SignalSentPacket;
135*d9f75844SAndroid Build Coastguard Worker 
136*d9f75844SAndroid Build Coastguard Worker   virtual std::string ToString() const = 0;
137*d9f75844SAndroid Build Coastguard Worker 
138*d9f75844SAndroid Build Coastguard Worker   virtual void GetStunStats(absl::optional<StunStats>* stats) = 0;
139*d9f75844SAndroid Build Coastguard Worker 
140*d9f75844SAndroid Build Coastguard Worker  protected:
141*d9f75844SAndroid Build Coastguard Worker   PortInterface();
142*d9f75844SAndroid Build Coastguard Worker };
143*d9f75844SAndroid Build Coastguard Worker 
144*d9f75844SAndroid Build Coastguard Worker }  // namespace cricket
145*d9f75844SAndroid Build Coastguard Worker 
146*d9f75844SAndroid Build Coastguard Worker #endif  // P2P_BASE_PORT_INTERFACE_H_
147