mirror of
https://gogs.blitter.com/RLabs/xs
synced 2024-08-14 10:26:42 +00:00
f5be3578a8
2/3 Added vendor/ dir to lock down dependent pkg versions. The author of git.schwanenlied.me/yawning/{chacha20,newhope,kyber}.git has copied their repos to gitlab.com/yawning/ but some imports of chacha20 from newhope still inconsistently refer to git.schwanenlied.me/, breaking build. Licenses for chacha20 also changed from CC0 to AGPL, which may or may not be an issue. Until the two aforementioned issues are resolved, locking to last-good versions is probably the best way forward for now. To build with vendored deps, use make VENDOR=1 clean all 3/3 Moved body of CI push script into bacillus/
64 lines
1.3 KiB
Go
64 lines
1.3 KiB
Go
// Copyright 2017 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package socket
|
|
|
|
import (
|
|
"errors"
|
|
"net"
|
|
"os"
|
|
"syscall"
|
|
)
|
|
|
|
// A Conn represents a raw connection.
|
|
type Conn struct {
|
|
network string
|
|
c syscall.RawConn
|
|
}
|
|
|
|
// NewConn returns a new raw connection.
|
|
func NewConn(c net.Conn) (*Conn, error) {
|
|
var err error
|
|
var cc Conn
|
|
switch c := c.(type) {
|
|
case *net.TCPConn:
|
|
cc.network = "tcp"
|
|
cc.c, err = c.SyscallConn()
|
|
case *net.UDPConn:
|
|
cc.network = "udp"
|
|
cc.c, err = c.SyscallConn()
|
|
case *net.IPConn:
|
|
cc.network = "ip"
|
|
cc.c, err = c.SyscallConn()
|
|
default:
|
|
return nil, errors.New("unknown connection type")
|
|
}
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return &cc, nil
|
|
}
|
|
|
|
func (o *Option) get(c *Conn, b []byte) (int, error) {
|
|
var operr error
|
|
var n int
|
|
fn := func(s uintptr) {
|
|
n, operr = getsockopt(s, o.Level, o.Name, b)
|
|
}
|
|
if err := c.c.Control(fn); err != nil {
|
|
return 0, err
|
|
}
|
|
return n, os.NewSyscallError("getsockopt", operr)
|
|
}
|
|
|
|
func (o *Option) set(c *Conn, b []byte) error {
|
|
var operr error
|
|
fn := func(s uintptr) {
|
|
operr = setsockopt(s, o.Level, o.Name, b)
|
|
}
|
|
if err := c.c.Control(fn); err != nil {
|
|
return err
|
|
}
|
|
return os.NewSyscallError("setsockopt", operr)
|
|
}
|