package torrent
import (
- "fmt"
"net"
+ "strconv"
"time"
- "github.com/anacrolix/torrent/webtorrent"
"github.com/pion/datachannel"
"github.com/pion/webrtc/v3"
+ "go.opentelemetry.io/otel"
+ "go.opentelemetry.io/otel/attribute"
+ "go.opentelemetry.io/otel/trace"
+
+ "github.com/anacrolix/torrent/webtorrent"
)
const webrtcNetwork = "webrtc"
}
func (me webrtcNetAddr) String() string {
- // Probably makes sense to return the IP:port expected of most net.Addrs. I'm not sure if
- // Address would be quoted for IPv6 already. If not, net.JoinHostPort might be appropriate.
- return fmt.Sprintf("%s:%d", me.Address, me.Port)
+ return net.JoinHostPort(me.Address, strconv.FormatUint(uint64(me.Port), 10))
}
func (me webrtcNetConn) LocalAddr() net.Addr {
// PeerConnection or on the channel or some transport?
func (w webrtcNetConn) SetDeadline(t time.Time) error {
+ w.Span.AddEvent("SetDeadline", trace.WithAttributes(attribute.String("time", t.String())))
return nil
}
+
func (w webrtcNetConn) SetReadDeadline(t time.Time) error {
+ w.Span.AddEvent("SetReadDeadline", trace.WithAttributes(attribute.String("time", t.String())))
return nil
}
+
func (w webrtcNetConn) SetWriteDeadline(t time.Time) error {
+ w.Span.AddEvent("SetWriteDeadline", trace.WithAttributes(attribute.String("time", t.String())))
return nil
}
+
+func (w webrtcNetConn) Read(b []byte) (n int, err error) {
+ _, span := otel.Tracer(tracerName).Start(w.Context, "Read")
+ defer span.End()
+ span.SetAttributes(attribute.Int("buf_len", len(b)))
+ n, err = w.ReadWriteCloser.Read(b)
+ span.RecordError(err)
+ span.SetAttributes(attribute.Int("bytes_read", n))
+ return
+}