2022-03-10 09:44:48 +00:00
|
|
|
// Package stun implements Session Traversal Utilities for NAT (STUN) RFC 5389.
|
|
|
|
//
|
|
|
|
// The stun package is intended to use by package that implements extension
|
|
|
|
// to STUN (e.g. TURN) or client/server applications.
|
|
|
|
//
|
|
|
|
// Most methods are designed to be zero allocations. If it is not enough,
|
|
|
|
// low-level methods are available. On other hand, there are helpers that
|
|
|
|
// reduce code repeat.
|
|
|
|
//
|
|
|
|
// See examples for Message for basic usage, or https://github.com/pion/turn
|
|
|
|
// package for example of stun extension implementation.
|
|
|
|
package stun
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/binary"
|
|
|
|
"io"
|
|
|
|
)
|
|
|
|
|
|
|
|
// bin is shorthand to binary.BigEndian.
|
2024-01-18 18:54:54 +00:00
|
|
|
var bin = binary.BigEndian
|
2022-03-10 09:44:48 +00:00
|
|
|
|
|
|
|
func readFullOrPanic(r io.Reader, v []byte) int {
|
|
|
|
n, err := io.ReadFull(r, v)
|
|
|
|
if err != nil {
|
2024-01-18 18:54:54 +00:00
|
|
|
panic(err) // nolint
|
2022-03-10 09:44:48 +00:00
|
|
|
}
|
|
|
|
return n
|
|
|
|
}
|
|
|
|
|
|
|
|
func writeOrPanic(w io.Writer, v []byte) int {
|
|
|
|
n, err := w.Write(v)
|
|
|
|
if err != nil {
|
2024-01-18 18:54:54 +00:00
|
|
|
panic(err) // nolint
|
2022-03-10 09:44:48 +00:00
|
|
|
}
|
|
|
|
return n
|
|
|
|
}
|
|
|
|
|
|
|
|
// IANA assigned ports for "stun" protocol.
|
|
|
|
const (
|
|
|
|
DefaultPort = 3478
|
|
|
|
DefaultTLSPort = 5349
|
|
|
|
)
|
|
|
|
|
|
|
|
type transactionIDSetter struct{}
|
|
|
|
|
|
|
|
func (transactionIDSetter) AddTo(m *Message) error {
|
|
|
|
return m.NewTransactionID()
|
|
|
|
}
|
|
|
|
|
|
|
|
// TransactionID is Setter for m.TransactionID.
|
2024-01-18 18:54:54 +00:00
|
|
|
var TransactionID Setter = transactionIDSetter{}
|