52 lines
1.2 KiB
Go
Raw Normal View History

2022-03-10 10:44:48 +01: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.
var bin = binary.BigEndian
2022-03-10 10:44:48 +01:00
func readFullOrPanic(r io.Reader, v []byte) int {
n, err := io.ReadFull(r, v)
if err != nil {
panic(err) // nolint
2022-03-10 10:44:48 +01:00
}
return n
}
func writeOrPanic(w io.Writer, v []byte) int {
n, err := w.Write(v)
if err != nil {
panic(err) // nolint
2022-03-10 10:44:48 +01: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.
var TransactionID Setter = transactionIDSetter{}