NOPRESUBMIT=True # cpplint errors that aren't caused by this CL. NOTRY=True NOTREECHECKS=True TBR=kwiberg@webrtc.org, kjellander@webrtc.org Bug: webrtc:7634 Change-Id: I3cca0fbaa807b563c95979cccd6d1bec32055f36 Reviewed-on: https://chromium-review.googlesource.com/562156 Commit-Queue: Edward Lemur <ehmaldonado@webrtc.org> Reviewed-by: Mirko Bonadei <mbonadei@webrtc.org> Cr-Commit-Position: refs/heads/master@{#18919}
151 lines
5.2 KiB
C++
151 lines
5.2 KiB
C++
/*
|
|
* Copyright 2016 The WebRTC Project Authors. All rights reserved.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license
|
|
* that can be found in the LICENSE file in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
#ifndef WEBRTC_P2P_BASE_ICETRANSPORTINTERNAL_H_
|
|
#define WEBRTC_P2P_BASE_ICETRANSPORTINTERNAL_H_
|
|
|
|
#include <string>
|
|
|
|
#include "webrtc/p2p/base/candidate.h"
|
|
#include "webrtc/p2p/base/candidatepairinterface.h"
|
|
#include "webrtc/p2p/base/jseptransport.h"
|
|
#include "webrtc/p2p/base/packettransportinternal.h"
|
|
#include "webrtc/p2p/base/transportdescription.h"
|
|
#include "webrtc/rtc_base/stringencode.h"
|
|
|
|
namespace webrtc {
|
|
class MetricsObserverInterface;
|
|
}
|
|
|
|
namespace cricket {
|
|
|
|
// TODO(zhihuang): Replace this with
|
|
// PeerConnectionInterface::IceConnectionState.
|
|
enum class IceTransportState {
|
|
STATE_INIT,
|
|
STATE_CONNECTING, // Will enter this state once a connection is created
|
|
STATE_COMPLETED,
|
|
STATE_FAILED
|
|
};
|
|
|
|
// TODO(zhihuang): Remove this once it's no longer used in
|
|
// remoting/protocol/libjingle_transport_factory.cc
|
|
enum IceProtocolType {
|
|
ICEPROTO_RFC5245 // Standard RFC 5245 version of ICE.
|
|
};
|
|
|
|
// IceTransportInternal is an internal abstract class that does ICE.
|
|
// Once the public interface is supported,
|
|
// (https://www.w3.org/TR/webrtc/#rtcicetransport-interface)
|
|
// the IceTransportInterface will be split from this class.
|
|
class IceTransportInternal : public rtc::PacketTransportInternal {
|
|
public:
|
|
virtual ~IceTransportInternal(){};
|
|
|
|
virtual IceTransportState GetState() const = 0;
|
|
|
|
virtual const std::string& transport_name() const = 0;
|
|
|
|
virtual int component() const = 0;
|
|
|
|
virtual IceRole GetIceRole() const = 0;
|
|
|
|
virtual void SetIceRole(IceRole role) = 0;
|
|
|
|
virtual void SetIceTiebreaker(uint64_t tiebreaker) = 0;
|
|
|
|
// TODO(zhihuang): Remove this once it's no longer called in
|
|
// remoting/protocol/libjingle_transport_factory.cc
|
|
virtual void SetIceProtocolType(IceProtocolType type) {}
|
|
|
|
virtual void SetIceCredentials(const std::string& ice_ufrag,
|
|
const std::string& ice_pwd) {
|
|
SetIceParameters(IceParameters(ice_ufrag, ice_pwd, false));
|
|
}
|
|
|
|
virtual void SetRemoteIceCredentials(const std::string& ice_ufrag,
|
|
const std::string& ice_pwd) {
|
|
SetRemoteIceParameters(IceParameters(ice_ufrag, ice_pwd, false));
|
|
}
|
|
|
|
// The ufrag and pwd in |ice_params| must be set
|
|
// before candidate gathering can start.
|
|
virtual void SetIceParameters(const IceParameters& ice_params) = 0;
|
|
|
|
virtual void SetRemoteIceParameters(const IceParameters& ice_params) = 0;
|
|
|
|
virtual void SetRemoteIceMode(IceMode mode) = 0;
|
|
|
|
virtual void SetIceConfig(const IceConfig& config) = 0;
|
|
|
|
// Start gathering candidates if not already started, or if an ICE restart
|
|
// occurred.
|
|
virtual void MaybeStartGathering() = 0;
|
|
|
|
virtual void SetMetricsObserver(
|
|
webrtc::MetricsObserverInterface* observer) = 0;
|
|
|
|
virtual void AddRemoteCandidate(const Candidate& candidate) = 0;
|
|
|
|
virtual void RemoveRemoteCandidate(const Candidate& candidate) = 0;
|
|
|
|
virtual IceGatheringState gathering_state() const = 0;
|
|
|
|
// Returns the current stats for this connection.
|
|
virtual bool GetStats(ConnectionInfos* infos) = 0;
|
|
|
|
// Returns RTT estimate over the currently active connection, or an empty
|
|
// rtc::Optional if there is none.
|
|
virtual rtc::Optional<int> GetRttEstimate() = 0;
|
|
|
|
sigslot::signal1<IceTransportInternal*> SignalGatheringState;
|
|
|
|
// Handles sending and receiving of candidates.
|
|
sigslot::signal2<IceTransportInternal*, const Candidate&>
|
|
SignalCandidateGathered;
|
|
|
|
sigslot::signal2<IceTransportInternal*, const Candidates&>
|
|
SignalCandidatesRemoved;
|
|
|
|
// Deprecated by SignalSelectedCandidatePairChanged
|
|
// This signal occurs when there is a change in the way that packets are
|
|
// being routed, i.e. to a different remote location. The candidate
|
|
// indicates where and how we are currently sending media.
|
|
sigslot::signal2<IceTransportInternal*, const Candidate&> SignalRouteChange;
|
|
|
|
// Signalled when the current selected candidate pair has changed.
|
|
// The first parameter is the transport that signals the event.
|
|
// The second parameter is the new selected candidate pair. The third
|
|
// parameter is the last packet id sent on the previous candidate pair.
|
|
// The fourth parameter is a boolean which is true if the Transport
|
|
// is ready to send with this candidate pair.
|
|
sigslot::signal4<IceTransportInternal*, CandidatePairInterface*, int, bool>
|
|
SignalSelectedCandidatePairChanged;
|
|
|
|
// Invoked when there is conflict in the ICE role between local and remote
|
|
// agents.
|
|
sigslot::signal1<IceTransportInternal*> SignalRoleConflict;
|
|
|
|
// Emitted whenever the transport state changed.
|
|
sigslot::signal1<IceTransportInternal*> SignalStateChanged;
|
|
|
|
// Invoked when the transport is being destroyed.
|
|
sigslot::signal1<IceTransportInternal*> SignalDestroyed;
|
|
|
|
// Debugging description of this transport.
|
|
std::string debug_name() const override {
|
|
return transport_name() + " " + rtc::ToString(component());
|
|
}
|
|
};
|
|
|
|
} // namespace cricket
|
|
|
|
#endif // WEBRTC_P2P_BASE_ICETRANSPORTINTERNAL_H_
|