Documentation ¶
Index ¶
- Variables
- type Candidate
- func (*Candidate) Descriptor() ([]byte, []int)deprecated
- func (x *Candidate) GetAddress() string
- func (x *Candidate) GetComponent() int32
- func (x *Candidate) GetFoundation() string
- func (x *Candidate) GetNetworkType() NetworkType
- func (x *Candidate) GetPort() int32
- func (x *Candidate) GetPriority() int32
- func (x *Candidate) GetRelatedAddress() *RelatedAddress
- func (x *Candidate) GetRelayProtocol() RelayProtocol
- func (x *Candidate) GetTcpType() TCPType
- func (x *Candidate) GetType() CandidateType
- func (c *Candidate) ICECandidate() (ice.Candidate, error)
- func (*Candidate) ProtoMessage()
- func (x *Candidate) ProtoReflect() protoreflect.Message
- func (x *Candidate) Reset()
- func (x *Candidate) String() string
- func (c *Candidate) ToString() string
- type CandidatePair
- func (*CandidatePair) Descriptor() ([]byte, []int)deprecated
- func (x *CandidatePair) GetLocal() *Candidate
- func (x *CandidatePair) GetRemote() *Candidate
- func (*CandidatePair) ProtoMessage()
- func (x *CandidatePair) ProtoReflect() protoreflect.Message
- func (x *CandidatePair) Reset()
- func (x *CandidatePair) String() string
- func (cp *CandidatePair) ToString() string
- type CandidatePairState
- func (CandidatePairState) Descriptor() protoreflect.EnumDescriptor
- func (x CandidatePairState) Enum() *CandidatePairState
- func (CandidatePairState) EnumDescriptor() ([]byte, []int)deprecated
- func (x CandidatePairState) Number() protoreflect.EnumNumber
- func (x CandidatePairState) String() string
- func (CandidatePairState) Type() protoreflect.EnumType
- type CandidatePairStats
- func (*CandidatePairStats) Descriptor() ([]byte, []int)deprecated
- func (x *CandidatePairStats) GetAvailableIncomingBitrate() float64
- func (x *CandidatePairStats) GetAvailableOutgoingBitrate() float64
- func (x *CandidatePairStats) GetBytesReceived() uint64
- func (x *CandidatePairStats) GetBytesSent() uint64
- func (x *CandidatePairStats) GetCircuitBreakerTriggerCount() uint32
- func (x *CandidatePairStats) GetConsentExpiredTimestamp() *proto.Timestamp
- func (x *CandidatePairStats) GetConsentRequestsSent() uint64
- func (x *CandidatePairStats) GetCurrentRoundtripTime() float64
- func (x *CandidatePairStats) GetFirstRequestTimestamp() *proto.Timestamp
- func (x *CandidatePairStats) GetLastPacketReceivedTimestamp() *proto.Timestamp
- func (x *CandidatePairStats) GetLastPacketSentTimestamp() *proto.Timestamp
- func (x *CandidatePairStats) GetLastRequestTimestamp() *proto.Timestamp
- func (x *CandidatePairStats) GetLastResponseTimestamp() *proto.Timestamp
- func (x *CandidatePairStats) GetLocalCandidateId() string
- func (x *CandidatePairStats) GetNominated() bool
- func (x *CandidatePairStats) GetPacketsReceived() uint32
- func (x *CandidatePairStats) GetPacketsSent() uint32
- func (x *CandidatePairStats) GetRemoteCandidateId() string
- func (x *CandidatePairStats) GetRequestsReceived() uint64
- func (x *CandidatePairStats) GetRequestsSent() uint64
- func (x *CandidatePairStats) GetResponsesReceived() uint64
- func (x *CandidatePairStats) GetResponsesSent() uint64
- func (x *CandidatePairStats) GetRetransmissionsReceived() uint64
- func (x *CandidatePairStats) GetRetransmissionsSent() uint64
- func (x *CandidatePairStats) GetState() CandidatePairState
- func (x *CandidatePairStats) GetTimestamp() *proto.Timestamp
- func (x *CandidatePairStats) GetTotalRoundtripTime() float64
- func (*CandidatePairStats) ProtoMessage()
- func (x *CandidatePairStats) ProtoReflect() protoreflect.Message
- func (x *CandidatePairStats) Reset()
- func (x *CandidatePairStats) String() string
- type CandidateStats
- func (*CandidateStats) Descriptor() ([]byte, []int)deprecated
- func (cs *CandidateStats) Dump(wr io.Writer) error
- func (x *CandidateStats) GetCandidateType() CandidateType
- func (x *CandidateStats) GetDeleted() bool
- func (x *CandidateStats) GetId() string
- func (x *CandidateStats) GetIp() string
- func (x *CandidateStats) GetNetworkType() NetworkType
- func (x *CandidateStats) GetPort() int32
- func (x *CandidateStats) GetPriority() uint32
- func (x *CandidateStats) GetRelayProtocol() RelayProtocol
- func (x *CandidateStats) GetTimestamp() *proto.Timestamp
- func (x *CandidateStats) GetUrl() string
- func (*CandidateStats) ProtoMessage()
- func (x *CandidateStats) ProtoReflect() protoreflect.Message
- func (x *CandidateStats) Reset()
- func (x *CandidateStats) String() string
- func (cs *CandidateStats) ToString() string
- type CandidateType
- func (CandidateType) Descriptor() protoreflect.EnumDescriptor
- func (x CandidateType) Enum() *CandidateType
- func (CandidateType) EnumDescriptor() ([]byte, []int)deprecated
- func (x CandidateType) Number() protoreflect.EnumNumber
- func (x CandidateType) String() string
- func (CandidateType) Type() protoreflect.EnumType
- type ConnectionState
- func (ConnectionState) Descriptor() protoreflect.EnumDescriptor
- func (x ConnectionState) Enum() *ConnectionState
- func (ConnectionState) EnumDescriptor() ([]byte, []int)deprecated
- func (x ConnectionState) Number() protoreflect.EnumNumber
- func (x ConnectionState) String() string
- func (ConnectionState) Type() protoreflect.EnumType
- type Credentials
- func (*Credentials) Descriptor() ([]byte, []int)deprecated
- func (x *Credentials) GetNeedCreds() bool
- func (x *Credentials) GetPwd() string
- func (x *Credentials) GetUfrag() string
- func (*Credentials) ProtoMessage()
- func (x *Credentials) ProtoReflect() protoreflect.Message
- func (x *Credentials) Reset()
- func (x *Credentials) String() string
- type Interface
- func (*Interface) Descriptor() ([]byte, []int)deprecated
- func (i *Interface) Dump(wr io.Writer, level log.Level) error
- func (x *Interface) GetMuxPort() uint32
- func (x *Interface) GetMuxSrflxPort() uint32
- func (x *Interface) GetNatType() NATType
- func (*Interface) ProtoMessage()
- func (x *Interface) ProtoReflect() protoreflect.Message
- func (x *Interface) Reset()
- func (x *Interface) String() string
- type NATType
- type NetworkType
- func (NetworkType) Descriptor() protoreflect.EnumDescriptor
- func (x NetworkType) Enum() *NetworkType
- func (NetworkType) EnumDescriptor() ([]byte, []int)deprecated
- func (x NetworkType) Number() protoreflect.EnumNumber
- func (x NetworkType) String() string
- func (NetworkType) Type() protoreflect.EnumType
- type Peer
- func (*Peer) Descriptor() ([]byte, []int)deprecated
- func (p *Peer) Dump(wr io.Writer, level log.Level) error
- func (x *Peer) GetCandidatePairStats() []*CandidatePairStats
- func (x *Peer) GetLastStateChangeTimestamp() *proto.Timestamp
- func (x *Peer) GetLocalCandidateStats() []*CandidateStats
- func (x *Peer) GetProxyType() ProxyType
- func (x *Peer) GetRemoteCandidateStats() []*CandidateStats
- func (x *Peer) GetRestarts() uint32
- func (x *Peer) GetSelectedCandidatePair() *CandidatePair
- func (*Peer) ProtoMessage()
- func (x *Peer) ProtoReflect() protoreflect.Message
- func (x *Peer) Reset()
- func (x *Peer) String() string
- type ProxyType
- type RelatedAddress
- func (*RelatedAddress) Descriptor() ([]byte, []int)deprecated
- func (x *RelatedAddress) GetAddress() string
- func (x *RelatedAddress) GetPort() int32
- func (*RelatedAddress) ProtoMessage()
- func (x *RelatedAddress) ProtoReflect() protoreflect.Message
- func (x *RelatedAddress) Reset()
- func (x *RelatedAddress) String() string
- type RelayProtocol
- func (RelayProtocol) Descriptor() protoreflect.EnumDescriptor
- func (x RelayProtocol) Enum() *RelayProtocol
- func (RelayProtocol) EnumDescriptor() ([]byte, []int)deprecated
- func (x RelayProtocol) Number() protoreflect.EnumNumber
- func (x RelayProtocol) String() string
- func (p RelayProtocol) ToString() string
- func (RelayProtocol) Type() protoreflect.EnumType
- type TCPType
Constants ¶
This section is empty.
Variables ¶
var ( ConnectionState_name = map[int32]string{ 0: "NEW", 1: "CHECKING", 2: "CONNECTED", 3: "COMPLETED", 4: "FAILED", 5: "DISCONNECTED", 6: "CLOSED", } ConnectionState_value = map[string]int32{ "NEW": 0, "CHECKING": 1, "CONNECTED": 2, "COMPLETED": 3, "FAILED": 4, "DISCONNECTED": 5, "CLOSED": 6, } )
Enum value maps for ConnectionState.
var ( NATType_name = map[int32]string{ 0: "NONE", 1: "NFTABLES", } NATType_value = map[string]int32{ "NONE": 0, "NFTABLES": 1, } )
Enum value maps for NATType.
var ( ProxyType_name = map[int32]string{ 0: "NO_PROXY", 1: "USER_BIND", 2: "KERNEL_CONN", 3: "KERNEL_NAT", } ProxyType_value = map[string]int32{ "NO_PROXY": 0, "USER_BIND": 1, "KERNEL_CONN": 2, "KERNEL_NAT": 3, } )
Enum value maps for ProxyType.
var ( CandidatePairState_name = map[int32]string{ 0: "UNSPECIFIED_CANDIDATE_PAIR_STATE", 1: "WAITING", 2: "INPROGRESS", 3: "FAILED_", 4: "SUCCEEDED", } CandidatePairState_value = map[string]int32{ "UNSPECIFIED_CANDIDATE_PAIR_STATE": 0, "WAITING": 1, "INPROGRESS": 2, "FAILED_": 3, "SUCCEEDED": 4, } )
Enum value maps for CandidatePairState.
var ( CandidateType_name = map[int32]string{ 0: "UNSPECIFIED_CANDIDATE_TYPE", 1: "HOST", 2: "SERVER_REFLEXIVE", 3: "PEER_REFLEXIVE", 4: "RELAY", } CandidateType_value = map[string]int32{ "UNSPECIFIED_CANDIDATE_TYPE": 0, "HOST": 1, "SERVER_REFLEXIVE": 2, "PEER_REFLEXIVE": 3, "RELAY": 4, } )
Enum value maps for CandidateType.
var ( NetworkType_name = map[int32]string{ 0: "UNSPECIFIED_NETWORK_TYPE", 1: "UDP4", 2: "UDP6", 3: "TCP4", 4: "TCP6", } NetworkType_value = map[string]int32{ "UNSPECIFIED_NETWORK_TYPE": 0, "UDP4": 1, "UDP6": 2, "TCP4": 3, "TCP6": 4, } )
Enum value maps for NetworkType.
var ( TCPType_name = map[int32]string{ 0: "UNSPECIFIED_TCP_TYPE", 1: "ACTIVE", 2: "PASSIVE", 3: "SIMULTANEOUS_OPEN", } TCPType_value = map[string]int32{ "UNSPECIFIED_TCP_TYPE": 0, "ACTIVE": 1, "PASSIVE": 2, "SIMULTANEOUS_OPEN": 3, } )
Enum value maps for TCPType.
var ( RelayProtocol_name = map[int32]string{ 0: "UNSPECIFIED_RELAY_PROTOCOL", 1: "UDP", 2: "TCP", 3: "TLS", 4: "DTLS", } RelayProtocol_value = map[string]int32{ "UNSPECIFIED_RELAY_PROTOCOL": 0, "UDP": 1, "TCP": 2, "TLS": 3, "DTLS": 4, } )
Enum value maps for RelayProtocol.
var File_feature_epdisc_candidate_proto protoreflect.FileDescriptor
var File_feature_epdisc_proto protoreflect.FileDescriptor
Functions ¶
This section is empty.
Types ¶
type Candidate ¶
type Candidate struct { // The type of candidate Type CandidateType `protobuf:"varint,1,opt,name=type,proto3,enum=cunicu.epdisc.CandidateType" json:"type,omitempty"` NetworkType NetworkType `` /* 126-byte string literal not displayed */ TcpType TCPType `protobuf:"varint,3,opt,name=tcp_type,json=tcpType,proto3,enum=cunicu.epdisc.TCPType" json:"tcp_type,omitempty"` // An identifier that is equivalent for two candidates that are of the same type, share the same base, and come from the same STUN server. Foundation string `protobuf:"bytes,4,opt,name=foundation,proto3" json:"foundation,omitempty"` // A positive integer between 1 and 256 that identifies the specific component of the media stream for which this is a candidate. Component int32 `protobuf:"varint,5,opt,name=component,proto3" json:"component,omitempty"` // A positive integer between 1 and (2**31 - 1). Priority int32 `protobuf:"varint,6,opt,name=priority,proto3" json:"priority,omitempty"` // The IP address of the candidate. Address string `protobuf:"bytes,7,opt,name=address,proto3" json:"address,omitempty"` // The port of the candidate. Port int32 `protobuf:"varint,8,opt,name=port,proto3" json:"port,omitempty"` // The related address conveys transport addresses related to the candidate, useful for diagnostics and other purposes. RelatedAddress *RelatedAddress `protobuf:"bytes,9,opt,name=related_address,json=relatedAddress,proto3" json:"related_address,omitempty"` // The protocol used between the endpoint and the relay server. RelayProtocol RelayProtocol `` /* 135-byte string literal not displayed */ // contains filtered or unexported fields }
An ICE Candidate contains a transport address for a candidate that can be used for connectivity checks. See: https://datatracker.ietf.org/doc/html/rfc8839#section-5.1
func NewCandidate ¶
func NewCandidate(ic ice.Candidate) *Candidate
func (*Candidate) Descriptor
deprecated
func (*Candidate) GetAddress ¶
func (*Candidate) GetComponent ¶
func (*Candidate) GetFoundation ¶
func (*Candidate) GetNetworkType ¶
func (x *Candidate) GetNetworkType() NetworkType
func (*Candidate) GetPriority ¶
func (*Candidate) GetRelatedAddress ¶
func (x *Candidate) GetRelatedAddress() *RelatedAddress
func (*Candidate) GetRelayProtocol ¶
func (x *Candidate) GetRelayProtocol() RelayProtocol
func (*Candidate) GetTcpType ¶
func (*Candidate) GetType ¶
func (x *Candidate) GetType() CandidateType
func (*Candidate) ICECandidate ¶
func (*Candidate) ProtoMessage ¶
func (*Candidate) ProtoMessage()
func (*Candidate) ProtoReflect ¶
func (x *Candidate) ProtoReflect() protoreflect.Message
type CandidatePair ¶
type CandidatePair struct { Local *Candidate `protobuf:"bytes,1,opt,name=local,proto3" json:"local,omitempty"` Remote *Candidate `protobuf:"bytes,2,opt,name=remote,proto3" json:"remote,omitempty"` // contains filtered or unexported fields }
func (*CandidatePair) Descriptor
deprecated
func (*CandidatePair) Descriptor() ([]byte, []int)
Deprecated: Use CandidatePair.ProtoReflect.Descriptor instead.
func (*CandidatePair) GetLocal ¶
func (x *CandidatePair) GetLocal() *Candidate
func (*CandidatePair) GetRemote ¶
func (x *CandidatePair) GetRemote() *Candidate
func (*CandidatePair) ProtoMessage ¶
func (*CandidatePair) ProtoMessage()
func (*CandidatePair) ProtoReflect ¶
func (x *CandidatePair) ProtoReflect() protoreflect.Message
func (*CandidatePair) Reset ¶
func (x *CandidatePair) Reset()
func (*CandidatePair) String ¶
func (x *CandidatePair) String() string
func (*CandidatePair) ToString ¶
func (cp *CandidatePair) ToString() string
type CandidatePairState ¶
type CandidatePairState int32
const ( CandidatePairState_UNSPECIFIED_CANDIDATE_PAIR_STATE CandidatePairState = 0 // CandidatePairStateWaiting means a check has not been performed for // this pair CandidatePairState_WAITING CandidatePairState = 1 // CandidatePairStateInProgress means a check has been sent for this pair, // but the transaction is in progress. CandidatePairState_INPROGRESS CandidatePairState = 2 // CandidatePairStateFailed means a check for this pair was already done // and failed, either never producing any response or producing an unrecoverable // failure response. CandidatePairState_FAILED_ CandidatePairState = 3 // CandidatePairStateSucceeded means a check for this pair was already // done and produced a successful result. CandidatePairState_SUCCEEDED CandidatePairState = 4 )
func (CandidatePairState) Descriptor ¶
func (CandidatePairState) Descriptor() protoreflect.EnumDescriptor
func (CandidatePairState) Enum ¶
func (x CandidatePairState) Enum() *CandidatePairState
func (CandidatePairState) EnumDescriptor
deprecated
func (CandidatePairState) EnumDescriptor() ([]byte, []int)
Deprecated: Use CandidatePairState.Descriptor instead.
func (CandidatePairState) Number ¶
func (x CandidatePairState) Number() protoreflect.EnumNumber
func (CandidatePairState) String ¶
func (x CandidatePairState) String() string
func (CandidatePairState) Type ¶
func (CandidatePairState) Type() protoreflect.EnumType
type CandidatePairStats ¶
type CandidatePairStats struct { // Timestamp is the timestamp associated with this object. Timestamp *proto.Timestamp `protobuf:"bytes,1,opt,name=timestamp,proto3" json:"timestamp,omitempty"` // LocalCandidateID is the ID of the local candidate LocalCandidateId string `protobuf:"bytes,2,opt,name=local_candidate_id,json=localCandidateId,proto3" json:"local_candidate_id,omitempty"` // RemoteCandidateID is the ID of the remote candidate RemoteCandidateId string `protobuf:"bytes,3,opt,name=remote_candidate_id,json=remoteCandidateId,proto3" json:"remote_candidate_id,omitempty"` // State represents the state of the checklist for the local and remote // candidates in a pair. State CandidatePairState `protobuf:"varint,4,opt,name=state,proto3,enum=cunicu.epdisc.CandidatePairState" json:"state,omitempty"` // Nominated is true when this valid pair that should be used for media // if it is the highest-priority one amongst those whose nominated flag is set Nominated bool `protobuf:"varint,5,opt,name=nominated,proto3" json:"nominated,omitempty"` // PacketsSent represents the total number of packets sent on this candidate pair. PacketsSent uint32 `protobuf:"varint,6,opt,name=packets_sent,json=packetsSent,proto3" json:"packets_sent,omitempty"` // PacketsReceived represents the total number of packets received on this candidate pair. PacketsReceived uint32 `protobuf:"varint,7,opt,name=packets_received,json=packetsReceived,proto3" json:"packets_received,omitempty"` // BytesSent represents the total number of payload bytes sent on this candidate pair // not including headers or padding. BytesSent uint64 `protobuf:"varint,8,opt,name=bytes_sent,json=bytesSent,proto3" json:"bytes_sent,omitempty"` // BytesReceived represents the total number of payload bytes received on this candidate pair // not including headers or padding. BytesReceived uint64 `protobuf:"varint,9,opt,name=bytes_received,json=bytesReceived,proto3" json:"bytes_received,omitempty"` // LastPacketSentTimestamp represents the timestamp at which the last packet was // sent on this particular candidate pair, excluding STUN packets. LastPacketSentTimestamp *proto.Timestamp `` /* 135-byte string literal not displayed */ // LastPacketReceivedTimestamp represents the timestamp at which the last packet // was received on this particular candidate pair, excluding STUN packets. LastPacketReceivedTimestamp *proto.Timestamp `` /* 147-byte string literal not displayed */ // FirstRequestTimestamp represents the timestamp at which the first STUN request // was sent on this particular candidate pair. FirstRequestTimestamp *proto.Timestamp `` /* 127-byte string literal not displayed */ // LastRequestTimestamp represents the timestamp at which the last STUN request // was sent on this particular candidate pair. The average interval between two // consecutive connectivity checks sent can be calculated with // (LastRequestTimestamp - FirstRequestTimestamp) / RequestsSent. LastRequestTimestamp *proto.Timestamp `protobuf:"bytes,13,opt,name=last_request_timestamp,json=lastRequestTimestamp,proto3" json:"last_request_timestamp,omitempty"` // LastResponseTimestamp represents the timestamp at which the last STUN response // was received on this particular candidate pair. LastResponseTimestamp *proto.Timestamp `` /* 127-byte string literal not displayed */ // TotalRoundTripTime represents the sum of all round trip time measurements // in seconds since the beginning of the session, based on STUN connectivity // check responses (ResponsesReceived), including those that reply to requests // that are sent in order to verify consent. The average round trip time can // be computed from TotalRoundTripTime by dividing it by ResponsesReceived. TotalRoundtripTime float64 `protobuf:"fixed64,15,opt,name=total_roundtrip_time,json=totalRoundtripTime,proto3" json:"total_roundtrip_time,omitempty"` // CurrentRoundTripTime represents the latest round trip time measured in seconds, // computed from both STUN connectivity checks, including those that are sent // for consent verification. CurrentRoundtripTime float64 `` /* 126-byte string literal not displayed */ // AvailableOutgoingBitrate is calculated by the underlying congestion control // by combining the available bitrate for all the outgoing RTP streams using // this candidate pair. The bitrate measurement does not count the size of the // IP or other transport layers like TCP or UDP. It is similar to the TIAS defined // in RFC 3890, i.e., it is measured in bits per second and the bitrate is calculated // over a 1 second window. AvailableOutgoingBitrate float64 `` /* 138-byte string literal not displayed */ // AvailableIncomingBitrate is calculated by the underlying congestion control // by combining the available bitrate for all the incoming RTP streams using // this candidate pair. The bitrate measurement does not count the size of the // IP or other transport layers like TCP or UDP. It is similar to the TIAS defined // in RFC 3890, i.e., it is measured in bits per second and the bitrate is // calculated over a 1 second window. AvailableIncomingBitrate float64 `` /* 138-byte string literal not displayed */ // CircuitBreakerTriggerCount represents the number of times the circuit breaker // is triggered for this particular 5-tuple, ceasing transmission. CircuitBreakerTriggerCount uint32 `` /* 145-byte string literal not displayed */ // RequestsReceived represents the total number of connectivity check requests // received (including retransmissions). It is impossible for the receiver to // tell whether the request was sent in order to check connectivity or check // consent, so all connectivity checks requests are counted here. RequestsReceived uint64 `protobuf:"varint,20,opt,name=requests_received,json=requestsReceived,proto3" json:"requests_received,omitempty"` // RequestsSent represents the total number of connectivity check requests // sent (not including retransmissions). RequestsSent uint64 `protobuf:"varint,21,opt,name=requests_sent,json=requestsSent,proto3" json:"requests_sent,omitempty"` // ResponsesReceived represents the total number of connectivity check responses received. ResponsesReceived uint64 `protobuf:"varint,22,opt,name=responses_received,json=responsesReceived,proto3" json:"responses_received,omitempty"` // ResponsesSent epresents the total number of connectivity check responses sent. // Since we cannot distinguish connectivity check requests and consent requests, // all responses are counted. ResponsesSent uint64 `protobuf:"varint,23,opt,name=responses_sent,json=responsesSent,proto3" json:"responses_sent,omitempty"` // RetransmissionsReceived represents the total number of connectivity check // request retransmissions received. RetransmissionsReceived uint64 `` /* 132-byte string literal not displayed */ // RetransmissionsSent represents the total number of connectivity check // request retransmissions sent. RetransmissionsSent uint64 `protobuf:"varint,25,opt,name=retransmissions_sent,json=retransmissionsSent,proto3" json:"retransmissions_sent,omitempty"` // ConsentRequestsSent represents the total number of consent requests sent. ConsentRequestsSent uint64 `protobuf:"varint,26,opt,name=consent_requests_sent,json=consentRequestsSent,proto3" json:"consent_requests_sent,omitempty"` // ConsentExpiredTimestamp represents the timestamp at which the latest valid // STUN binding response expired. ConsentExpiredTimestamp *proto.Timestamp `` /* 133-byte string literal not displayed */ // contains filtered or unexported fields }
CandidatePairStats contains ICE candidate pair statistics
func NewCandidatePairStats ¶
func NewCandidatePairStats(cps *ice.CandidatePairStats) *CandidatePairStats
func (*CandidatePairStats) Descriptor
deprecated
func (*CandidatePairStats) Descriptor() ([]byte, []int)
Deprecated: Use CandidatePairStats.ProtoReflect.Descriptor instead.
func (*CandidatePairStats) GetAvailableIncomingBitrate ¶
func (x *CandidatePairStats) GetAvailableIncomingBitrate() float64
func (*CandidatePairStats) GetAvailableOutgoingBitrate ¶
func (x *CandidatePairStats) GetAvailableOutgoingBitrate() float64
func (*CandidatePairStats) GetBytesReceived ¶
func (x *CandidatePairStats) GetBytesReceived() uint64
func (*CandidatePairStats) GetBytesSent ¶
func (x *CandidatePairStats) GetBytesSent() uint64
func (*CandidatePairStats) GetCircuitBreakerTriggerCount ¶
func (x *CandidatePairStats) GetCircuitBreakerTriggerCount() uint32
func (*CandidatePairStats) GetConsentExpiredTimestamp ¶
func (x *CandidatePairStats) GetConsentExpiredTimestamp() *proto.Timestamp
func (*CandidatePairStats) GetConsentRequestsSent ¶
func (x *CandidatePairStats) GetConsentRequestsSent() uint64
func (*CandidatePairStats) GetCurrentRoundtripTime ¶
func (x *CandidatePairStats) GetCurrentRoundtripTime() float64
func (*CandidatePairStats) GetFirstRequestTimestamp ¶
func (x *CandidatePairStats) GetFirstRequestTimestamp() *proto.Timestamp
func (*CandidatePairStats) GetLastPacketReceivedTimestamp ¶
func (x *CandidatePairStats) GetLastPacketReceivedTimestamp() *proto.Timestamp
func (*CandidatePairStats) GetLastPacketSentTimestamp ¶
func (x *CandidatePairStats) GetLastPacketSentTimestamp() *proto.Timestamp
func (*CandidatePairStats) GetLastRequestTimestamp ¶
func (x *CandidatePairStats) GetLastRequestTimestamp() *proto.Timestamp
func (*CandidatePairStats) GetLastResponseTimestamp ¶
func (x *CandidatePairStats) GetLastResponseTimestamp() *proto.Timestamp
func (*CandidatePairStats) GetLocalCandidateId ¶
func (x *CandidatePairStats) GetLocalCandidateId() string
func (*CandidatePairStats) GetNominated ¶
func (x *CandidatePairStats) GetNominated() bool
func (*CandidatePairStats) GetPacketsReceived ¶
func (x *CandidatePairStats) GetPacketsReceived() uint32
func (*CandidatePairStats) GetPacketsSent ¶
func (x *CandidatePairStats) GetPacketsSent() uint32
func (*CandidatePairStats) GetRemoteCandidateId ¶
func (x *CandidatePairStats) GetRemoteCandidateId() string
func (*CandidatePairStats) GetRequestsReceived ¶
func (x *CandidatePairStats) GetRequestsReceived() uint64
func (*CandidatePairStats) GetRequestsSent ¶
func (x *CandidatePairStats) GetRequestsSent() uint64
func (*CandidatePairStats) GetResponsesReceived ¶
func (x *CandidatePairStats) GetResponsesReceived() uint64
func (*CandidatePairStats) GetResponsesSent ¶
func (x *CandidatePairStats) GetResponsesSent() uint64
func (*CandidatePairStats) GetRetransmissionsReceived ¶
func (x *CandidatePairStats) GetRetransmissionsReceived() uint64
func (*CandidatePairStats) GetRetransmissionsSent ¶
func (x *CandidatePairStats) GetRetransmissionsSent() uint64
func (*CandidatePairStats) GetState ¶
func (x *CandidatePairStats) GetState() CandidatePairState
func (*CandidatePairStats) GetTimestamp ¶
func (x *CandidatePairStats) GetTimestamp() *proto.Timestamp
func (*CandidatePairStats) GetTotalRoundtripTime ¶
func (x *CandidatePairStats) GetTotalRoundtripTime() float64
func (*CandidatePairStats) ProtoMessage ¶
func (*CandidatePairStats) ProtoMessage()
func (*CandidatePairStats) ProtoReflect ¶
func (x *CandidatePairStats) ProtoReflect() protoreflect.Message
func (*CandidatePairStats) Reset ¶
func (x *CandidatePairStats) Reset()
func (*CandidatePairStats) String ¶
func (x *CandidatePairStats) String() string
type CandidateStats ¶
type CandidateStats struct { // Timestamp is the timestamp associated with this object. Timestamp *proto.Timestamp `protobuf:"bytes,1,opt,name=timestamp,proto3" json:"timestamp,omitempty"` // ID is the candidate ID Id string `protobuf:"bytes,2,opt,name=id,proto3" json:"id,omitempty"` // NetworkType represents the type of network interface used by the base of a // local candidate (the address the ICE agent sends from). Only present for // local candidates; it's not possible to know what type of network interface // a remote candidate is using. // // Note: // This stat only tells you about the network interface used by the first "hop"; // it's possible that a connection will be bottlenecked by another type of network. // For example, when using Wi-Fi tethering, the networkType of the relevant candidate // would be "wifi", even when the next hop is over a cellular connection. NetworkType NetworkType `` /* 126-byte string literal not displayed */ // IP is the IP address of the candidate, allowing for IPv4 addresses and // IPv6 addresses, but fully qualified domain names (FQDNs) are not allowed. Ip string `protobuf:"bytes,4,opt,name=ip,proto3" json:"ip,omitempty"` // Port is the port number of the candidate. Port int32 `protobuf:"varint,5,opt,name=port,proto3" json:"port,omitempty"` // CandidateType is the "Type" field of the ICECandidate. CandidateType CandidateType `` /* 134-byte string literal not displayed */ // Priority is the "Priority" field of the ICECandidate. Priority uint32 `protobuf:"varint,7,opt,name=priority,proto3" json:"priority,omitempty"` // URL is the URL of the TURN or STUN server indicated in the that translated // this IP address. It is the URL address surfaced in an PeerConnectionICEEvent. Url string `protobuf:"bytes,8,opt,name=url,proto3" json:"url,omitempty"` // RelayProtocol is the protocol used by the endpoint to communicate with the // TURN server. This is only present for local candidates. Valid values for // the TURN URL protocol is one of udp, tcp, or tls. RelayProtocol RelayProtocol `` /* 134-byte string literal not displayed */ // Deleted is true if the candidate has been deleted/freed. For host candidates, // this means that any network resources (typically a socket) associated with the // candidate have been released. For TURN candidates, this means the TURN allocation // is no longer active. // // Only defined for local candidates. For remote candidates, this property is not applicable. Deleted bool `protobuf:"varint,10,opt,name=deleted,proto3" json:"deleted,omitempty"` // contains filtered or unexported fields }
CandidateStats contains ICE candidate statistics related to the ICETransport objects.
func NewCandidateStats ¶
func NewCandidateStats(cs *ice.CandidateStats) *CandidateStats
func (*CandidateStats) Descriptor
deprecated
func (*CandidateStats) Descriptor() ([]byte, []int)
Deprecated: Use CandidateStats.ProtoReflect.Descriptor instead.
func (*CandidateStats) GetCandidateType ¶
func (x *CandidateStats) GetCandidateType() CandidateType
func (*CandidateStats) GetDeleted ¶
func (x *CandidateStats) GetDeleted() bool
func (*CandidateStats) GetId ¶
func (x *CandidateStats) GetId() string
func (*CandidateStats) GetIp ¶
func (x *CandidateStats) GetIp() string
func (*CandidateStats) GetNetworkType ¶
func (x *CandidateStats) GetNetworkType() NetworkType
func (*CandidateStats) GetPort ¶
func (x *CandidateStats) GetPort() int32
func (*CandidateStats) GetPriority ¶
func (x *CandidateStats) GetPriority() uint32
func (*CandidateStats) GetRelayProtocol ¶
func (x *CandidateStats) GetRelayProtocol() RelayProtocol
func (*CandidateStats) GetTimestamp ¶
func (x *CandidateStats) GetTimestamp() *proto.Timestamp
func (*CandidateStats) GetUrl ¶
func (x *CandidateStats) GetUrl() string
func (*CandidateStats) ProtoMessage ¶
func (*CandidateStats) ProtoMessage()
func (*CandidateStats) ProtoReflect ¶
func (x *CandidateStats) ProtoReflect() protoreflect.Message
func (*CandidateStats) Reset ¶
func (x *CandidateStats) Reset()
func (*CandidateStats) String ¶
func (x *CandidateStats) String() string
func (*CandidateStats) ToString ¶
func (cs *CandidateStats) ToString() string
type CandidateType ¶
type CandidateType int32
ICE Candidate types See: https://datatracker.ietf.org/doc/html/rfc8445#section-5.1.1
const ( CandidateType_UNSPECIFIED_CANDIDATE_TYPE CandidateType = 0 CandidateType_HOST CandidateType = 1 CandidateType_SERVER_REFLEXIVE CandidateType = 2 CandidateType_PEER_REFLEXIVE CandidateType = 3 CandidateType_RELAY CandidateType = 4 )
func (CandidateType) Descriptor ¶
func (CandidateType) Descriptor() protoreflect.EnumDescriptor
func (CandidateType) Enum ¶
func (x CandidateType) Enum() *CandidateType
func (CandidateType) EnumDescriptor
deprecated
func (CandidateType) EnumDescriptor() ([]byte, []int)
Deprecated: Use CandidateType.Descriptor instead.
func (CandidateType) Number ¶
func (x CandidateType) Number() protoreflect.EnumNumber
func (CandidateType) String ¶
func (x CandidateType) String() string
func (CandidateType) Type ¶
func (CandidateType) Type() protoreflect.EnumType
type ConnectionState ¶
type ConnectionState int32
ICE Connection state from pion/ice/ice.go
const ( ConnectionState_NEW ConnectionState = 0 // ICE agent is gathering addresses ConnectionState_CHECKING ConnectionState = 1 // ICE agent has been given local and remote candidates, and is attempting to find a match ConnectionState_CONNECTED ConnectionState = 2 // ICE agent has a pairing, but is still checking other pairs ConnectionState_COMPLETED ConnectionState = 3 // ICE agent has finished ConnectionState_FAILED ConnectionState = 4 // ICE agent never could successfully connect ConnectionState_DISCONNECTED ConnectionState = 5 // ICE agent connected successfully, but has entered a failed state ConnectionState_CLOSED ConnectionState = 6 // ICE agent has finished and is no longer handling requests )
func NewConnectionState ¶
func NewConnectionState(cs ice.ConnectionState) ConnectionState
func (ConnectionState) Descriptor ¶
func (ConnectionState) Descriptor() protoreflect.EnumDescriptor
func (ConnectionState) Enum ¶
func (x ConnectionState) Enum() *ConnectionState
func (ConnectionState) EnumDescriptor
deprecated
func (ConnectionState) EnumDescriptor() ([]byte, []int)
Deprecated: Use ConnectionState.Descriptor instead.
func (ConnectionState) Number ¶
func (x ConnectionState) Number() protoreflect.EnumNumber
func (ConnectionState) String ¶
func (x ConnectionState) String() string
func (ConnectionState) Type ¶
func (ConnectionState) Type() protoreflect.EnumType
type Credentials ¶
type Credentials struct { // ICE username fragment Ufrag string `protobuf:"bytes,1,opt,name=ufrag,proto3" json:"ufrag,omitempty"` // ICE password Pwd string `protobuf:"bytes,2,opt,name=pwd,proto3" json:"pwd,omitempty"` // Flag to indicate that the sending peer requests the credentials of the receiving peer NeedCreds bool `protobuf:"varint,3,opt,name=need_creds,json=needCreds,proto3" json:"need_creds,omitempty"` // contains filtered or unexported fields }
func NewCredentials ¶
func NewCredentials() *Credentials
func (*Credentials) Descriptor
deprecated
func (*Credentials) Descriptor() ([]byte, []int)
Deprecated: Use Credentials.ProtoReflect.Descriptor instead.
func (*Credentials) GetNeedCreds ¶
func (x *Credentials) GetNeedCreds() bool
func (*Credentials) GetPwd ¶
func (x *Credentials) GetPwd() string
func (*Credentials) GetUfrag ¶
func (x *Credentials) GetUfrag() string
func (*Credentials) ProtoMessage ¶
func (*Credentials) ProtoMessage()
func (*Credentials) ProtoReflect ¶
func (x *Credentials) ProtoReflect() protoreflect.Message
func (*Credentials) Reset ¶
func (x *Credentials) Reset()
func (*Credentials) String ¶
func (x *Credentials) String() string
type Interface ¶
type Interface struct { NatType NATType `protobuf:"varint,1,opt,name=nat_type,json=natType,proto3,enum=cunicu.epdisc.NATType" json:"nat_type,omitempty"` MuxPort uint32 `protobuf:"varint,2,opt,name=mux_port,json=muxPort,proto3" json:"mux_port,omitempty"` MuxSrflxPort uint32 `protobuf:"varint,3,opt,name=mux_srflx_port,json=muxSrflxPort,proto3" json:"mux_srflx_port,omitempty"` // contains filtered or unexported fields }
func (*Interface) Descriptor
deprecated
func (*Interface) GetMuxPort ¶
func (*Interface) GetMuxSrflxPort ¶
func (*Interface) GetNatType ¶
func (*Interface) ProtoMessage ¶
func (*Interface) ProtoMessage()
func (*Interface) ProtoReflect ¶
func (x *Interface) ProtoReflect() protoreflect.Message
type NATType ¶
type NATType int32
func (NATType) Descriptor ¶
func (NATType) Descriptor() protoreflect.EnumDescriptor
func (NATType) EnumDescriptor
deprecated
func (NATType) Number ¶
func (x NATType) Number() protoreflect.EnumNumber
func (NATType) Type ¶
func (NATType) Type() protoreflect.EnumType
type NetworkType ¶
type NetworkType int32
const ( NetworkType_UNSPECIFIED_NETWORK_TYPE NetworkType = 0 NetworkType_UDP4 NetworkType = 1 NetworkType_UDP6 NetworkType = 2 NetworkType_TCP4 NetworkType = 3 NetworkType_TCP6 NetworkType = 4 )
func (NetworkType) Descriptor ¶
func (NetworkType) Descriptor() protoreflect.EnumDescriptor
func (NetworkType) Enum ¶
func (x NetworkType) Enum() *NetworkType
func (NetworkType) EnumDescriptor
deprecated
func (NetworkType) EnumDescriptor() ([]byte, []int)
Deprecated: Use NetworkType.Descriptor instead.
func (NetworkType) Number ¶
func (x NetworkType) Number() protoreflect.EnumNumber
func (NetworkType) String ¶
func (x NetworkType) String() string
func (NetworkType) Type ¶
func (NetworkType) Type() protoreflect.EnumType
type Peer ¶
type Peer struct { ProxyType ProxyType `protobuf:"varint,1,opt,name=proxy_type,json=proxyType,proto3,enum=cunicu.epdisc.ProxyType" json:"proxy_type,omitempty"` SelectedCandidatePair *CandidatePair `` /* 126-byte string literal not displayed */ LocalCandidateStats []*CandidateStats `protobuf:"bytes,6,rep,name=local_candidate_stats,json=localCandidateStats,proto3" json:"local_candidate_stats,omitempty"` RemoteCandidateStats []*CandidateStats `protobuf:"bytes,7,rep,name=remote_candidate_stats,json=remoteCandidateStats,proto3" json:"remote_candidate_stats,omitempty"` CandidatePairStats []*CandidatePairStats `protobuf:"bytes,8,rep,name=candidate_pair_stats,json=candidatePairStats,proto3" json:"candidate_pair_stats,omitempty"` LastStateChangeTimestamp *proto.Timestamp `` /* 137-byte string literal not displayed */ Restarts uint32 `protobuf:"varint,10,opt,name=restarts,proto3" json:"restarts,omitempty"` // contains filtered or unexported fields }
func (*Peer) Descriptor
deprecated
func (*Peer) GetCandidatePairStats ¶
func (x *Peer) GetCandidatePairStats() []*CandidatePairStats
func (*Peer) GetLastStateChangeTimestamp ¶
func (*Peer) GetLocalCandidateStats ¶
func (x *Peer) GetLocalCandidateStats() []*CandidateStats
func (*Peer) GetProxyType ¶
func (*Peer) GetRemoteCandidateStats ¶
func (x *Peer) GetRemoteCandidateStats() []*CandidateStats
func (*Peer) GetRestarts ¶
func (*Peer) GetSelectedCandidatePair ¶
func (x *Peer) GetSelectedCandidatePair() *CandidatePair
func (*Peer) ProtoMessage ¶
func (*Peer) ProtoMessage()
func (*Peer) ProtoReflect ¶
func (x *Peer) ProtoReflect() protoreflect.Message
type ProxyType ¶
type ProxyType int32
func (ProxyType) Descriptor ¶
func (ProxyType) Descriptor() protoreflect.EnumDescriptor
func (ProxyType) EnumDescriptor
deprecated
func (ProxyType) Number ¶
func (x ProxyType) Number() protoreflect.EnumNumber
func (ProxyType) Type ¶
func (ProxyType) Type() protoreflect.EnumType
type RelatedAddress ¶
type RelatedAddress struct { Address string `protobuf:"bytes,1,opt,name=address,proto3" json:"address,omitempty"` Port int32 `protobuf:"varint,2,opt,name=port,proto3" json:"port,omitempty"` // contains filtered or unexported fields }
The Related Address conveys transport addresses related to the candidate, useful for diagnostics and other purposes. See: https://datatracker.ietf.org/doc/html/rfc8839#section-5.1
func (*RelatedAddress) Descriptor
deprecated
func (*RelatedAddress) Descriptor() ([]byte, []int)
Deprecated: Use RelatedAddress.ProtoReflect.Descriptor instead.
func (*RelatedAddress) GetAddress ¶
func (x *RelatedAddress) GetAddress() string
func (*RelatedAddress) GetPort ¶
func (x *RelatedAddress) GetPort() int32
func (*RelatedAddress) ProtoMessage ¶
func (*RelatedAddress) ProtoMessage()
func (*RelatedAddress) ProtoReflect ¶
func (x *RelatedAddress) ProtoReflect() protoreflect.Message
func (*RelatedAddress) Reset ¶
func (x *RelatedAddress) Reset()
func (*RelatedAddress) String ¶
func (x *RelatedAddress) String() string
type RelayProtocol ¶
type RelayProtocol int32
const ( RelayProtocol_UNSPECIFIED_RELAY_PROTOCOL RelayProtocol = 0 RelayProtocol_UDP RelayProtocol = 1 RelayProtocol_TCP RelayProtocol = 2 RelayProtocol_TLS RelayProtocol = 3 RelayProtocol_DTLS RelayProtocol = 4 )
func NewProtocol ¶
func NewProtocol(rp string) RelayProtocol
func (RelayProtocol) Descriptor ¶
func (RelayProtocol) Descriptor() protoreflect.EnumDescriptor
func (RelayProtocol) Enum ¶
func (x RelayProtocol) Enum() *RelayProtocol
func (RelayProtocol) EnumDescriptor
deprecated
func (RelayProtocol) EnumDescriptor() ([]byte, []int)
Deprecated: Use RelayProtocol.Descriptor instead.
func (RelayProtocol) Number ¶
func (x RelayProtocol) Number() protoreflect.EnumNumber
func (RelayProtocol) String ¶
func (x RelayProtocol) String() string
func (RelayProtocol) ToString ¶
func (p RelayProtocol) ToString() string
func (RelayProtocol) Type ¶
func (RelayProtocol) Type() protoreflect.EnumType
type TCPType ¶
type TCPType int32
Type of TCP candidate See: https://datatracker.ietf.org/doc/html/rfc6544
func (TCPType) Descriptor ¶
func (TCPType) Descriptor() protoreflect.EnumDescriptor
func (TCPType) EnumDescriptor
deprecated
func (TCPType) Number ¶
func (x TCPType) Number() protoreflect.EnumNumber
func (TCPType) Type ¶
func (TCPType) Type() protoreflect.EnumType