cmd: extract listening on a UNIX socket in a private directory into a helper func

This commit is contained in:
Christian Schwarz
2017-09-17 23:41:51 +02:00
parent 1a62d635a6
commit aea62a9d85
2 changed files with 27 additions and 15 deletions

26
cmd/helpers.go Normal file
View File

@@ -0,0 +1,26 @@
package cmd
import (
"github.com/pkg/errors"
"net"
"os"
"path/filepath"
)
func ListenUnixPrivate(sockaddr *net.UnixAddr) (*net.UnixListener, error) {
sockdir := filepath.Dir(sockaddr.Name)
sdstat, err := os.Stat(sockdir)
if err != nil {
return nil, errors.Wrapf(err, "cannot stat(2) '%s'", sockdir)
}
if !sdstat.IsDir() {
return nil, errors.Errorf("%s is not a directory: %s", sockdir)
}
p := sdstat.Mode().Perm()
if p&0007 != 0 {
return nil, errors.Errorf("%s must not be world-accessible (permissions are %#o)", p)
}
return net.ListenUnix("unix", sockaddr)
}