81 lines
3.2 KiB
Markdown
81 lines
3.2 KiB
Markdown
# CHANGELOG
|
|
|
|
## v0.4.1
|
|
|
|
- [Bug Fix] [commit](https://github.com/mdlayher/socket/commit/2a14ceef4da279de1f957c5761fffcc6c87bbd3b):
|
|
ensure `socket.Conn` can be used with non-socket file descriptors by handling
|
|
`ENOTSOCK` in the constructor.
|
|
|
|
## v0.4.0
|
|
|
|
**This is the first release of package socket that only supports Go 1.18+.
|
|
Users on older versions of Go must use v0.3.0.**
|
|
|
|
- [Improvement]: drop support for older versions of Go so we can begin using
|
|
modern versions of `x/sys` and other dependencies.
|
|
|
|
## v0.3.0
|
|
|
|
**This is the last release of package socket that supports Go 1.17 and below.**
|
|
|
|
- [New API/API change] [PR](https://github.com/mdlayher/socket/pull/8):
|
|
numerous `socket.Conn` methods now support context cancelation. Future
|
|
releases will continue adding support as needed.
|
|
- New `ReadContext` and `WriteContext` methods.
|
|
- `Connect`, `Recvfrom`, `Recvmsg`, `Sendmsg`, and `Sendto` methods now accept
|
|
a context.
|
|
- `Sendto` parameter order was also fixed to match the underlying syscall.
|
|
|
|
## v0.2.3
|
|
|
|
- [New API] [commit](https://github.com/mdlayher/socket/commit/a425d96e0f772c053164f8ce4c9c825380a98086):
|
|
`socket.Conn` has new `Pidfd*` methods for wrapping the `pidfd_*(2)` family of
|
|
system calls.
|
|
|
|
## v0.2.2
|
|
|
|
- [New API] [commit](https://github.com/mdlayher/socket/commit/a2429f1dfe8ec2586df5a09f50ead865276cd027):
|
|
`socket.Conn` has new `IoctlKCM*` methods for wrapping `ioctl(2)` for `AF_KCM`
|
|
operations.
|
|
|
|
## v0.2.1
|
|
|
|
- [New API] [commit](https://github.com/mdlayher/socket/commit/b18ddbe9caa0e34552b4409a3aa311cb460d2f99):
|
|
`socket.Conn` has a new `SetsockoptPacketMreq` method for wrapping
|
|
`setsockopt(2)` for `AF_PACKET` socket options.
|
|
|
|
## v0.2.0
|
|
|
|
- [New API] [commit](https://github.com/mdlayher/socket/commit/6e912a68523c45e5fd899239f4b46c402dd856da):
|
|
`socket.FileConn` can be used to create a `socket.Conn` from an existing
|
|
`os.File`, which may be provided by systemd socket activation or another
|
|
external mechanism.
|
|
- [API change] [commit](https://github.com/mdlayher/socket/commit/66d61f565188c23fe02b24099ddc856d538bf1a7):
|
|
`socket.Conn.Connect` now returns the `unix.Sockaddr` value provided by
|
|
`getpeername(2)`, since we have to invoke that system call anyway to verify
|
|
that a connection to a remote peer was successfully established.
|
|
- [Bug Fix] [commit](https://github.com/mdlayher/socket/commit/b60b2dbe0ac3caff2338446a150083bde8c5c19c):
|
|
check the correct error from `unix.GetsockoptInt` in the `socket.Conn.Connect`
|
|
method. Thanks @vcabbage!
|
|
|
|
## v0.1.2
|
|
|
|
- [Bug Fix]: `socket.Conn.Connect` now properly checks the `SO_ERROR` socket
|
|
option value after calling `connect(2)` to verify whether or not a connection
|
|
could successfully be established. This means that `Connect` should now report
|
|
an error for an `AF_INET` TCP connection refused or `AF_VSOCK` connection
|
|
reset by peer.
|
|
- [New API]: add `socket.Conn.Getpeername` for use in `Connect`, but also for
|
|
use by external callers.
|
|
|
|
## v0.1.1
|
|
|
|
- [New API]: `socket.Conn` now has `CloseRead`, `CloseWrite`, and `Shutdown`
|
|
methods.
|
|
- [Improvement]: internal rework to more robustly handle various errors.
|
|
|
|
## v0.1.0
|
|
|
|
- Initial unstable release. Most functionality has been developed and ported
|
|
from package [`netlink`](https://github.com/mdlayher/netlink).
|