Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(145)

Unified Diff: webrtc/p2p/base/p2ptransportchannel.h

Issue 2590063002: Make P2PTransportChannel inherit from IceTransportInternal. (Closed)
Patch Set: Modified the debug_name(). Created 4 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « webrtc/p2p/base/jseptransport.h ('k') | webrtc/p2p/base/p2ptransportchannel.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: webrtc/p2p/base/p2ptransportchannel.h
diff --git a/webrtc/p2p/base/p2ptransportchannel.h b/webrtc/p2p/base/p2ptransportchannel.h
index e538dc2c9739f466ac603daeceb1e353a46a9df6..2327b2d4771b776e3086fc484e12841257e6160f 100644
--- a/webrtc/p2p/base/p2ptransportchannel.h
+++ b/webrtc/p2p/base/p2ptransportchannel.h
@@ -26,14 +26,14 @@
#include <string>
#include <vector>
+#include "webrtc/base/asyncpacketsocket.h"
#include "webrtc/base/constructormagic.h"
+#include "webrtc/base/sigslot.h"
#include "webrtc/p2p/base/candidate.h"
#include "webrtc/p2p/base/candidatepairinterface.h"
+#include "webrtc/p2p/base/icetransportinternal.h"
#include "webrtc/p2p/base/portallocator.h"
#include "webrtc/p2p/base/portinterface.h"
-#include "webrtc/p2p/base/transportchannelimpl.h"
-#include "webrtc/base/asyncpacketsocket.h"
-#include "webrtc/base/sigslot.h"
namespace cricket {
@@ -60,7 +60,7 @@ class RemoteCandidate : public Candidate {
// P2PTransportChannel manages the candidates and connection process to keep
// two P2P clients connected to each other.
-class P2PTransportChannel : public TransportChannelImpl,
+class P2PTransportChannel : public IceTransportInternal,
public rtc::MessageHandler {
public:
P2PTransportChannel(const std::string& transport_name,
@@ -69,7 +69,11 @@ class P2PTransportChannel : public TransportChannelImpl,
virtual ~P2PTransportChannel();
// From TransportChannelImpl:
- TransportChannelState GetState() const override;
+ IceTransportState GetState() const override;
+ const std::string& transport_name() const override { return transport_name_; }
+ int component() const override { return component_; }
+ bool writable() const override { return writable_; }
+ bool receiving() const override { return receiving_; }
void SetIceRole(IceRole role) override;
IceRole GetIceRole() const override { return ice_role_; }
void SetIceTiebreaker(uint64_t tiebreaker) override;
@@ -118,57 +122,6 @@ class P2PTransportChannel : public TransportChannelImpl,
IceMode remote_ice_mode() const { return remote_ice_mode_; }
- // DTLS methods.
- bool IsDtlsActive() const override { return false; }
-
- // Default implementation.
- bool GetSslRole(rtc::SSLRole* role) const override { return false; }
-
- bool SetSslRole(rtc::SSLRole role) override { return false; }
-
- // Set up the ciphers to use for DTLS-SRTP.
- bool SetSrtpCryptoSuites(const std::vector<int>& ciphers) override {
- return false;
- }
-
- // Find out which DTLS-SRTP cipher was negotiated.
- bool GetSrtpCryptoSuite(int* cipher) override { return false; }
-
- // Find out which DTLS cipher was negotiated.
- bool GetSslCipherSuite(int* cipher) override { return false; }
-
- // Returns null because the channel is not encrypted by default.
- rtc::scoped_refptr<rtc::RTCCertificate> GetLocalCertificate() const override {
- return nullptr;
- }
-
- std::unique_ptr<rtc::SSLCertificate> GetRemoteSSLCertificate()
- const override {
- return nullptr;
- }
-
- // Allows key material to be extracted for external encryption.
- bool ExportKeyingMaterial(const std::string& label,
- const uint8_t* context,
- size_t context_len,
- bool use_context,
- uint8_t* result,
- size_t result_len) override {
- return false;
- }
-
- bool SetLocalCertificate(
- const rtc::scoped_refptr<rtc::RTCCertificate>& certificate) override {
- return false;
- }
-
- // Set DTLS Remote fingerprint. Must be after local identity set.
- bool SetRemoteFingerprint(const std::string& digest_alg,
- const uint8_t* digest,
- size_t digest_len) override {
- return false;
- }
-
void PruneAllPorts();
int receiving_timeout() const { return config_.receiving_timeout; }
int check_receiving_interval() const { return check_receiving_interval_; }
@@ -193,6 +146,15 @@ class P2PTransportChannel : public TransportChannelImpl,
return remote_candidates_;
}
+ std::string ToString() const {
+ const char RECEIVING_ABBREV[2] = {'_', 'R'};
+ const char WRITABLE_ABBREV[2] = {'_', 'W'};
+ std::stringstream ss;
+ ss << "Channel[" << transport_name_ << "|" << component_ << "|"
+ << RECEIVING_ABBREV[receiving_] << WRITABLE_ABBREV[writable_] << "]";
+ return ss.str();
+ }
+
private:
rtc::Thread* thread() const { return network_thread_; }
bool IsGettingPorts() { return allocator_session()->IsGettingPorts(); }
@@ -239,7 +201,7 @@ class P2PTransportChannel : public TransportChannelImpl,
void UpdateState();
void HandleAllTimedOut();
void MaybeStopPortAllocatorSessions();
- TransportChannelState ComputeState() const;
+ IceTransportState ComputeState() const;
Connection* GetBestConnectionOnNetwork(rtc::Network* network) const;
bool CreateConnections(const Candidate& remote_candidate,
@@ -347,6 +309,13 @@ class P2PTransportChannel : public TransportChannelImpl,
: static_cast<uint32_t>(remote_ice_parameters_.size() - 1);
}
+ // Sets the writable state, signaling if necessary.
+ void set_writable(bool writable);
+ // Sets the receiving state, signaling if necessary.
+ void set_receiving(bool receiving);
+
+ std::string transport_name_;
+ int component_;
PortAllocator* allocator_;
rtc::Thread* network_thread_;
bool incoming_only_;
@@ -387,13 +356,15 @@ class P2PTransportChannel : public TransportChannelImpl,
int check_receiving_interval_;
int64_t last_ping_sent_ms_ = 0;
int weak_ping_interval_ = WEAK_PING_INTERVAL;
- TransportChannelState state_ = TransportChannelState::STATE_INIT;
+ IceTransportState state_ = IceTransportState::STATE_INIT;
IceConfig config_;
int last_sent_packet_id_ = -1; // -1 indicates no packet was sent before.
bool started_pinging_ = false;
// The value put in the "nomination" attribute for the next nominated
// connection. A zero-value indicates the connection will not be nominated.
uint32_t nomination_ = 0;
+ bool receiving_ = false;
+ bool writable_ = false;
webrtc::MetricsObserverInterface* metrics_observer_ = nullptr;
« no previous file with comments | « webrtc/p2p/base/jseptransport.h ('k') | webrtc/p2p/base/p2ptransportchannel.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698